mysql 中 exists 与 in 的底层分析

您所在的位置:网站首页 底层思维和底层逻辑区别 mysql 中 exists 与 in 的底层分析

mysql 中 exists 与 in 的底层分析

2024-07-14 17:29| 来源: 网络整理| 查看: 265

 

in 虽然和 or 有一定的区别,但单从整体逻辑和执行计划来看,相差无几,所以关于 in 的使用,宏观是可以看成(...or ...or......)

 

in : 把外表和内表作hash 连接exists : 对外表作loop循环,每次loop循环再对内表进行查询 1. 如果查询的两个表大小相当,那么用in和exists差别不大;2. 如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in:

参考文献:

http://blog.sina.com.cn/s/blog_3edc5e2e0102uzjn.html

http://blog.itpub.net/28912557/viewspace-1255568/

 



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3