gpt4 book ai didi

mysql - 删除查询中大表IN子查询的性能

转载 作者:行者123 更新时间:2023-11-29 01:51:50 25 4
gpt4 key购买 nike

我想知道,为什么使用 IN-Operator 的查询比简单的 SELECT 慢得多。

让我用一个例子来证明我的观察:

Query1: SELECT VIDEO_ID FROM videos (about 8000 rows with 1 column)

Query2: DELETE FROM video_snapshot WHERE video_snapshot.VIDEO_ID IN (Query1)

video_snapshot 是一个非常大的表,有超过 7.000.000 行,但 VIDEO_ID 已编入索引,因此在 WHERE 子句中使用 VIDEO_ID 的查询速度足够快。

IN 运算符如何工作?我猜这只是多个 WHERE 子句的缩写形式。

我在 XAMPP 上使用 MariaDB 10.1.16

最佳答案

对于大型数据集表,IN 子句性能非常慢,在这种情况下您可以使用 INNER JOIN 和删除查询

DELETE video_snapshot FROM video_snapshot
INNER JOIN videos ON video_snapshot.VIDEO_ID=videos.VIDEO_ID;

In my experience IN is a very slow operator, since SQL normally evaluates it as a series of WHERE clauses separated by "OR" (WHERE x=Y OR x=Z OR...).. BUT mainly explicit join is faster when need to compare field with other table field.

关于mysql - 删除查询中大表IN子查询的性能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39634970/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com