打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
[转]sql中exists和in的区别

以前看过一次关于这两的区别,但由于印象不深就忘了,最近想起来就补了下,为了加深印象,就写了 。

exists和in

in 是把外表和内表作hash join,而exists是对外表作loop,每次loop再对内表进行查询。
如:

A:select * from t1 a where exists (select * from t2 b where b.id = a.id)B:select * from t1 a where a.id in (select b.id from t2 b)

对于A,用到了t2上的id索引,exists执行次数为t1.length,不缓存exists的结果集。
对于B,用到了t1上的id索引,首先执行in语句,然后将结果缓存起来,之后遍历t1表,将满足结果的加入结果集,所以执行次数为t1.length*t2.length次。
因此对t1表大t2表小的情况使用in,t2表小t1表大的情况使用exists

not exists和not in

A:select * from t1 a where not exists (select * from t2 b where b.id = a.id)B:select * from t1 a where a.id not in (select b.id from t2 b)

对于A,和exists一样,用到了t2上的id索引,exists()执行次数为t1.length,不缓存exists()的结果集。
而对于B,因为not in实质上等于!= and != ···,因为!=不会使用索引,故not in不会使用索引。
因此,不管t1和t2大小如何,均使用not exists效率会更高。

作者:kasuganokaze
链接:https://www.jianshu.com/p/df614c2c901b
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
exist和in的区别
EXISTS、IN、NOT EXISTS、NOT IN的区别与性能分析
Sql语句中IN和exists的区别及应用
浅谈sql中的in与not in,exists与not exists的区别
一直搞不清楚in和exists两者到底有什么区别,今天总算搞清楚了
数据库:SQLServer中in和 exists函数用法笔记
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服