`

mysql 中的 in & exists比较与使用

 
阅读更多

in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。一直以来认为exists比in效率高的说法是不准确的。
如果查询的两个表大小相当,那么用in和exists差别不大。
如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in:
例如:表A(小表),表B(大表)

1:

select * from A where cc in (select cc from B) 效率低,用到了A表上cc列的索引;

select * from A where exists(select cc from B where cc=A.cc) 效率高,用到了B表上cc列的索引。
相反的

2:

select * from B where cc in (select cc from A) 效率高,用到了B表上cc列的索引;

select * from B where exists(select cc from A where cc=B.cc) 效率低,用到了A表上cc列的索引。


not in 和not exists如果查询语句使用了not in 那么内外表都进行全表扫描,没有用到索引;而not extsts 的子查询依然能用到表上的索引。所以无论那个表大,用not exists都比not in要快。
in 与 =的区别
select name from student where name in ('zhang','wang','li','zhao');

select name from student where name='zhang' or name='li' or name='wang' or name='zhao'
的结果是相同的。

分享到:
评论

相关推荐

    搞懂mysql的exists

    在理解`EXISTS`的使用时,我们需要深入探讨其工作原理、优缺点以及与其他查询操作(如`IN`、`JOIN`)的对比。 一、`EXISTS`的基本用法 `EXISTS`子句通常与子查询一起使用,形式如下: ```sql SELECT column1, ...

    MySQL中in与exists的使用及区别介绍

    在MySQL中,`IN` 和 `EXISTS` 都是用来在查询中筛选满足特定条件的行,但它们的工作原理和性能表现有所不同。了解这两者的差异对于优化SQL查询至关重要。 首先,`IN` 关键字用于在主查询中比较某个列的值是否存在于...

    mysql多表查询和EXISTS查询性能对比

    在进行MySQL多表查询与EXISTS查询的性能对比之前,首先需要了解测试环境的相关配置。虽然原文中并未给出具体的测试环境细节,但在实际操作中,这一步骤至关重要。通常会涉及到服务器硬件配置(如CPU、内存)、操作...

    MySQL中的in,exists,not in,not exists查询过程对比及结论

    MySQL优化之in,exists,not in,not exists的区别in与existsin查询过程结论:exists查询过程:结论:not in与not existsnot in查询过程:结论:not exists查询过程:结论: 首先我们使用两个用户表作为实例 insert ...

    mysql exists与not exists实例详解

    mysql exists与not exists实例详解 tableA |column1 | column1 |column3 | tableb |column1 | column1 |column3 | 要查询 tableA 的数据,条件是是 tableA.column1 不在 tableB 的 tableB.column2 中 也就是要得到...

    MYSQL IN 与 EXISTS 的优化示例介绍

    无论使用 `IN` 还是 `EXISTS`,确保涉及的字段(如上述例子中的`ID`字段)有合适的索引至关重要。索引可以帮助数据库快速定位到匹配的行,显著提高查询性能。 ### `NOT IN` 和 `NOT EXISTS` `NOT IN` 和 `NOT ...

    mySQL中in查询与exists查询的区别小结

    MySQL中的`IN`查询和`EXISTS`查询都是在处理子查询时常用的操作,它们各自有不同的特性和适用场景。理解两者的区别对于优化SQL查询性能至关重要。 ### `IN`查询 `IN`查询通常用于检查某列的值是否在特定的值列表中...

    mysql not in、left join、IS NULL、NOT EXISTS 效率问题记录

    MySQL中的`NOT IN`, `LEFT JOIN`, `IS NULL`, 和 `NOT EXISTS` 是四种不同的SQL查询方式,它们在特定情况下可以实现相似的功能,但实际执行效率可能会有很大差异。本文主要探讨这四种方法在处理大数据量时的性能表现...

    MySQL exists 和in 详解及区别

    MySQL中的`EXISTS`和`IN`都是在SQL查询中用来检查特定条件是否存在的子查询操作符,但它们的工作方式和适用场景有所不同。下面将详细解释这两个操作符的用法和区别。 ### `EXISTS`操作符 `EXISTS`主要用于判断子...

    mysql数据库In的优化.txt

    - 如果`IN`子句中的值过多,MySQL可能会选择全表扫描而非使用索引。 - 这是因为MySQL在评估查询计划时会认为全表扫描的成本更低。 #### 四、优化策略 ##### 4.1 使用临时表 1. **原理**: - 创建一个临时表,...

    sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句

    在查询中,我们可以使用EXISTS和NOT EXISTS来代替IN和NOT IN。例如,我们要查询Sendorder表中的冗余数据(没有和reg_person或worksite相连的数据): ```sql select Sendorder.id, Sendorder.reads, Sendorder....

    对比分析MySQL语句中的IN 和Exists

    `IN` 的查询通常会创建一个临时结果集,然后在主查询中进行比较,而 `EXISTS` 会遍历主查询中的每一行,看是否存在匹配子查询条件的记录。 在一般情况下,如果外部表(主查询的表)小,内部表(子查询的表)大,...

    SQL复习-EXISTS谓词

    三、EXISTS与IN和JOIN的比较 1. EXISTS vs IN: - EXISTS更关注于是否存在匹配的行,而IN则关心具体匹配的值。在处理大量数据时,如果子查询返回的值较少,IN可能更快;反之,如果子查询返回很多行,EXISTS通常...

    mysql insert if not exists防止插入重复记录的方法

    在MySQL中,当我们需要向数据库表中插入数据时,但又希望避免插入已经存在的记录,可以采用`INSERT IGNORE`、`REPLACE INTO`或者结合`SELECT`与`NOT EXISTS`子句的方式来实现。这里我们将详细探讨`NOT EXISTS`子句在...

Global site tag (gtag.js) - Google Analytics