mysql in 性能分析_干货:MySQL性能优化,in和exists

本文分析了SQL中'in'和'exists'关键字在查询优化中的区别:in通过先子查询后主查询,可能导致多次查询;exists则为主查询驱动子查询,效率高。讨论了内外层循环嵌套原则,并推荐在内外表大小关系上使用in(表大内表小)和exists(表小内表大)的方法。
摘要由CSDN通过智能技术生成

20fa05363b8a5f92997e1d193dea6f13.png

(2)select count(1) from orders o where exists (select 1 from users u where u.id = o.user_id);

17976c4a368c3d2c0872d5172a97ecdc.png

2.where后面是大表

(1)select count(1) from users u where u.id in (select o.user_id from orders o);

88ba254212a729d3330c2512873c50b6.png

(2)select count(1) from users u where exists (select 1 from orders o where o.user_id = u.id);

db007c5826a0c4e37067e94a6c16f02a.png

分析

我们用下面的这两条语句分析:

select count(1) from orders o where o.user_id in(select u.id from users u); select count(1) from orders o where exists (select 1 from users u where u.id = o.user_id);

1.in:先查询in后面的users表,然后再去orders中过滤,也就是先执行子查询,结果出来后,再遍历主查询,遍历主查询是根据user_id和id相等查询的。

即查询users表相当于外层循环,主查询就是外层循环

小结:in先执行子查询,也就是in()所包含的语句。子查询查询出数据以后,将前面的查询分为n次普通查询(n表示在子查询中返回的数据行数)

2.exists:主查询是内层循环,先查询出orders,查询orders就是外层循环,然后会判断是不是存在order_id和 users表中的id相等,相等才保留数据,查询users表就是内层循环

这里所说的外层循环和内层循环就是我们所说的嵌套循环,而嵌套循环应该遵循“外小内大”的原则,这就好比你复制很多个小文件和复制几个大文件的区别

小结:如果子查询查到数据,就返回布尔值true;如果没有,就返回布尔值false。返回布尔值true则将该条数据保存下来,否则就舍弃掉。也就是说exists查询,是查询出一条数据就执行一次子查询

结论

小表驱动大表。

in适合于外表大而内表小的情况,exists适合于外表小而内表大的情况。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值