EXISTS替代IN、NOT EXISTS替代NOT IN的SQL优化
温馨提示:
本文最后更新于 2023年02月18日,已超过 431 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我。
在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下, 使用EXISTS(或NOT EXISTS)通常将提高查询的效率。在子查询中,NOT IN子句将执行一个内部的排序和合并。无论在哪种情况下,NOT IN都是最低效的 (因为它对子查询中的表执行了一个全表遍历)。为了避免使用NOT IN ,我们可以把它改写成外连接(Outer Joins)或NOT EXISTS。
如:
查询 Sendorder表中的冗余数据(没有和reg_person或worksite相连的数据)
select Sendorder.id,Sendorder.reads,Sendorder.addtime from Sendorder where Sendorder.person_id not in(select user_id from reg_person ) or Sendorder.worksite_id not in(select id from worksite) order by Sendorder.addtime desc
程序执行时间:40109.38毫秒
--------------------------------------------------
select Sendorder.id,Sendorder.reads,Sendorder.addtime from Sendorder where not EXISTS (SELECT id FROM reg_person where reg_person.user_id=Sendorder.person_id) or not EXISTS (SELECT id FROM worksite where worksite.id=Sendorder.worksite_id) order by Sendorder.addtime desc
程序执行时间:8531.25毫秒
--------------------------------------------------
很明显使用not EXISTS效率高多了
正文到此结束
- 本文标签: Sql SQL Server函数 其他
- 本文链接: http://www.92cxy.cn/article/84
- 版权声明: 本文由王小东原创发布,转载请遵循《署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)》许可协议授权
热门推荐
相关文章
该篇文章的评论功能已被站长关闭