In、or、exists、not in、not exists

11 篇文章 2 订阅
11 篇文章 2 订阅

目录

in和or:没有索引或主键时,随数据量增多,or性能急剧下降

in和exists:主表小、子表大用exists;主表大、子表小用in

not in和not exists:无论哪个表大,not exists都比not in快


in和or:没有索引或主键时,随数据量增多,or性能急剧下降

前提条件:所在的列是否有索引或者主键。

in和or所在列有索引或主键:or和in没啥差别,执行计划和执行时间都几乎一样;

in和or所在列没有索引或主键:性能差别大了。在没有索引的情况下,随着in或者or后面的数据量越多,in的效率不会有太大的下降,但是or会随着记录增多而性能急剧下降

 所在列有索引或主键所在列没有索引或主键
in执行计划和执行时间几乎一样随数据量增多,效率不会太大下降
or执行计划和执行时间几乎一样随数据量增多,性能急剧下降

 

exists和in:主表小、子表大用exists;主表大、子表小用in

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


/* 主表小子表大用exists */

-->效率高,用到了BigTable上cc列的索引
select *
  from SmallTable
 where exists (select cc from BigTable where cc = SmallTable.cc);

-->效率低,用到了SmallTable上cc列的索引
-->select * from SmallTable where cc in (select cc from BigTable);

----------------------------------------------------------------------------- 

/* 主表大子表小用in */

-->效率高,用到了BigTable上cc列的索引
select * from BigTable where cc in (select cc from SmallTable);
  

-->效率低,用到了SmallTable上cc列的索引
-->select * from BigTable where exists (select cc from SmallTable where cc = BigTable.cc);

 

not exists和not in:无论哪个表大,not exists都比not in快

not in:内外表均全表扫,不会走索引

not exists子查询依然能用到表上的索引

所以无论哪个表大,not exists效率更高。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值