SQL Server sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句
发布时间:2020-05-23 20:40:00 所属栏目:MsSql 来源:互联网
导读:SQL Server sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句
|
感兴趣的小伙伴,下面一起跟随脚本之家 jb51.cc的小编两巴掌来看看吧! 在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下, 使用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.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 – 按日期范围内的频率划分的SQL组
- sql-server – 在“select top n”查询中返回未锁定的行
- SQL Server 将表数据生成Insert脚本 比较好用的生成插入语句
- 我们可以使用sql在msaccess数据库中列出所有表吗?
- 高性能MySQL读书笔记 找出谁持有锁
- 我们应该如何计算SQL中不同对/元组的数量?
- Driver.getConnection使用SQLServer驱动程序和Java 1.6.0_2
- linq-to-sql – 将Linq中的ChangeConflictException异常更新
- MSSQL SERVER中的BETWEEN AND的使用
