mysql中in和exists有什么区别
程序员文章站
2022-04-16 20:49:28
...
mysql中exists和in的区别有:1、in是把外表和内表做hash连接,先查询内表;2、exists是对外表做loop循环,循环后在对内表查询;3、在外表大的时用in效率更快,内表大用exists更快。
mysql中exists和in的区别有:
#对B查询涉及id,使用索引,故B表效率高,可用大表 -->外小内大 select * from A where exists (select * from B where A.id=B.id);
#对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数据库转移至sqlserver数据库中详解(mysql和sqlserver数据转移)
-
apple watch运动版和标准版有什么区别 apple watch运动版和标准版区别介绍
-
SQL SERVER中关于exists 和 in的简单分析
-
ABBYY FineReader简体中文版和多语言专业版有什么区别?
-
手机淘宝和电脑淘宝有什么区别(揭晓两种不同处)
-
小米盒子2要不要越狱?小米盒子2越狱和不越狱有什么区别?
-
网站运营是做什么的?和产品经理有什么区别?
-
营销型网站和传统网站有什么区别
-
mysql特点有哪些(mysql数据库特点和优势介绍)
-
手机淘宝和电脑淘宝有什么区别(揭晓两种不同处)