sql嵌套查询很慢——优化方案

本文探讨了一个原本运行缓慢的SQL嵌套查询,通过优化,将执行时间从4分钟缩短至0.03秒,最终达到0.00秒。分析了`IN`与`=`的区别,并解释了SQL查询的执行过程,揭示了嵌套查询效率低下的原因在于多次内存加载和M*N次查询。建议在查询中谨慎使用嵌套,尤其是当子查询可能返回多个值时,应优先考虑使用`IN`子句。
摘要由CSDN通过智能技术生成

工作需要写一个查询:

最开始写了最原始的嵌套查询:

select * from realservice where realservname in (select realservname from groupmember where groupname in (select groupname from v_group where vname in (select vname from vservice where vip = '10.181.65.185')));

发现很慢,查了一下用时4min 22.74sec。

然后考虑如何优化,自然想到了连接,然后优化后代码如下:

select * from realservice as a join groupmember as b where a.realservname=b.realservname and b.groupname in (select a.groupname from v_group as a join vservice as b where a.vnam
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值