sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句
程序员文章站
2022-06-11 18:16:34
在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下, 使用exists(或not exists)通常将提高查询的效率。...
在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下, 使用exists(或not exists)通常将提高查询的效率。在子查询中,not in子句将执行一个内部的排序和合并。无论在哪种情况下,not in都是最低效的 (因为它对子查询中的表执行了一个全表遍历)。为了避免使用not in ,我们可以把它改写成外连接(outer joins)或not exists。
如
我要查询 sendorder表中的冗余数据(没有和reg_person或worksite相连的数据)
sql="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毫秒
sql="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效率高多了
如
我要查询 sendorder表中的冗余数据(没有和reg_person或worksite相连的数据)
sql="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毫秒
sql="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效率高多了
上一篇: 小米10定制黑鲨双翼手柄套装来了:299元 秒变“掌机”
下一篇: 网站改版过程中注意的4个细节