mysql中exists和in的区别

来源:互联网 发布:php字符串的拆分 编辑:程序博客网 时间:2024/05/21 21:33

exists ()后面的子查询被称作相关子查询 他是不返回列表的值,只返回一个boolean型的值。

其运行方式是先运行朱查询一次,再去子查询里查询与其对应的结果 如果是true 则输出,反之则不输出,在根据主查询中的每一行去子查询里去查询。

in()后面的子查询是返回的结果集,执行次序和exists()不一样,子查询先产生结果集,然后主查询再去结果集里去找符合要求的字段列表,符合要求的输出,反之不输出。

exists() 对外表用loap 逐条查询,每条查询都会查看exists的条件语句,当exists里的条件语句能够返回记录行时,条件就为真,返回当前loop到的这条记录。反之如果exists里的条件语句不能返回记录行,怎当前loop到的这条记录被丢弃,exists的条件就像一个bool条件,当能返回结果集则为TRUE,不能安徽结果集则返回false。

例如:

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' 
的结果是相同的。


1 0