mysql中in和exists有什么区别


本文摘自PHP中文网,作者清浅,侵删。

mysql中exists和in的区别有:1、in是把外表和内表做hash连接,先查询内表;2、exists是对外表做loop循环,循环后在对内表查询;3、在外表大的时用in效率更快,内表大用exists更快。

mysql中exists和in的区别有:

1

2

#对B查询涉及id,使用索引,故B表效率高,可用大表 -->外小内大

select * from A where exists (select * from B where A.id=B.id);

1

2

#对A查询涉及id,使用索引,故A表效率高,可用大表 -->外大内小

select * from A where A.id in (select id from B);

(1)exists是对外表做loop循环,每次loop循环再对内表(子查询)进行查询,那么因为对内表的查询使用的索引(内表效率高,故可用大表),而外表有多大都需要遍历,不可避免(尽量用小表),故内表大的使用exists,可加快效率;

(2)in是把外表和内表做hash连接,先查询内表,再把内表结果与外表匹配,对外表使用索引(外表效率高,可用大表),而内表多大都需要查询,不可避免,故外表大的使用in,可加快效率。

(3)如果查询的两个表大小相当,那么用in和exists差别不大。如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in。

以上就是mysql中in和exists有什么区别的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

mysql中关于exists和not exists的示例分享

关于mysql exists与not exists分析

mysql中 in和not in用法详解

mysql中in的用法是什么

oracle中exists的用法

oracle中exists有什么用法

mysql中in和exists有什么区别

sql中in的用法是什么

sql中带in条件的查询及提高效率

更多相关阅读请进入《in》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...