gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 24 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下,使用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语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句的文章就讲到这里了,如果你想了解更多关于sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com