MySQL中 not in 和 not exists 区别

在MySQL中,NOT IN和NOT EXISTS都是用于在子查询中测试条件的操作符,但它们在处理和效率上也有一些重要的区别。

处理方式:

NOT IN: 当使用NOT IN子查询时,查询首先执行子查询,然后将其结果与外部查询的每一行进行比较。这意味着子查询的结果集必须适合内存,并且结果集的大小对性能有很大影响。
NOT EXISTS: 与NOT IN不同,NOT EXISTS子查询在每次外部查询的行与子查询返回任何行时评估一次。这意味着子查询通常只返回一个值(即使对于每个外部查询的行),这使得其结果集的大小对性能的影响较小。

效率:

当子查询返回的结果集很大时,使用NOT IN可能会导致性能问题,因为所有结果都需要加载到内存中。而NOT EXISTS通常在这种情况下更高效,因为它只需要检查是否存在至少一个匹配的行,而不是检查所有行。
另一方面,当子查询返回的结果集很小并且可以适应内存时,使用NOT IN可能更高效,因为它可以避免多次打开和关闭游标等操作。

优化:

使用NOT EXISTS的查询通常更易于优化,因为它们通常只返回一个值。这使得索引的使用更加有效,从而提高了查询性能。
对于大型数据集,考虑将子查询结果集的大小降至最低,并使用适当的索引来优化性能。

not in 和not exists:如果查询语句使⽤了not in,那么内外表都进⾏全表扫描,没有⽤到索引;⽽not extsts的⼦查询依然能⽤到表上的索引。所以⽆论那个表⼤,⽤not exists都⽐not in要快。

相关推荐

  1. mysqlcharvarchar的区别

    2024-04-11 20:26:02       52 阅读
  2. MySQLvarchar char的区别

    2024-04-11 20:26:02       52 阅读
  3. MySQL in exists 区别

    2024-04-11 20:26:02       33 阅读
  4. mysqlexistsin的区别

    2024-04-11 20:26:02       35 阅读
  5. MySQLinexists的区别

    2024-04-11 20:26:02       25 阅读
  6. msSQLMySQL区别

    2024-04-11 20:26:02       73 阅读
  7. MySQL inexists的用法区别

    2024-04-11 20:26:02       37 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-11 20:26:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-11 20:26:02       101 阅读
  3. 在Django里面运行非项目文件

    2024-04-11 20:26:02       82 阅读
  4. Python语言-面向对象

    2024-04-11 20:26:02       91 阅读

热门阅读

  1. 分布式任务调度:架构、原理与实践

    2024-04-11 20:26:02       37 阅读
  2. 常见分类算法

    2024-04-11 20:26:02       31 阅读
  3. 【无标题】

    2024-04-11 20:26:02       23 阅读
  4. 中科软面试题

    2024-04-11 20:26:02       29 阅读
  5. 常见的正则表达式

    2024-04-11 20:26:02       38 阅读
  6. 牛客周赛39

    2024-04-11 20:26:02       34 阅读
  7. Cmake学习笔记3

    2024-04-11 20:26:02       41 阅读
  8. Nginx 调优面试题

    2024-04-11 20:26:02       29 阅读
  9. [CF825F] String Compression 题解

    2024-04-11 20:26:02       36 阅读