SQL Server sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句

2022-11-12 09:54:41
内容摘要
这篇文章主要为大家详细介绍了SQL Server sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句,具有一定的参考价值,可以用来参考一下。 对此感兴趣的朋友,看看idc笔
文章正文

这篇文章主要为大家详细介绍了SQL Server sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句,具有一定的参考价值,可以用来参考一下。

对此感兴趣的朋友,看看idc笔记做的技术笔记!

在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下,使用EXISTS(或NOTEXISTS)通常将提高查询的效率。在子查询中,NOTIN子句将执行一个内部的排序和合并。无论在哪种情况下,NOTIN都是最低效的(因为它对子查询中的表执行了一个全表遍历)。为了避免使用NOTIN,我们可以把它改写成外连接(OuterJoins)或NOTEXISTS。如我要查询Sendorder表中的冗余数据(没有和reg_person或worksite相连的数据)sql="selectSendorder.id,Sendorder.reads,Sendorder.addtimefromSendorderwhereSendorder.person_idnotin(selectuser_idfromreg_person)orSendorder.worksite_idnotin(selectidfromworksite)orderbySendorder.addtimedesc"程序执行时间:40109.38毫秒sql="selectSendorder.id,Sendorder.reads,Sendorder.addtimefromSendorderwherenotEXISTS(SELECTidFROMreg_personwherereg_person.user_id=Sendorder.person_id)ornotEXISTS(SELECTidFROMworksitewhereworksite.id=Sendorder.worksite_id)orderbySendorder.addtimedesc"程序执行时间:8531.25毫秒很明显使用notEXISTS效率高多了

注:关于SQL Server sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句的内容就先介绍到这里,更多相关文章的可以留意

代码注释

作者:喵哥笔记

IDC笔记

学的不仅是技术,更是梦想!