您现在的位置是:网站首页> 编程资料编程资料
sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句_MsSql_
2023-05-26
419人已围观
简介 sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句_MsSql_
在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下, 使用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效率高多了
您可能感兴趣的文章:
相关内容
- sql server中datetime字段去除时间的语句_MsSql_
- 在SQL中使用convert函数进行日期的查询的代码_MsSql_
- mssql中得到当天数据的语句_MsSql_
- [js]javascript与剪贴板交互_MsSql_
- mssql server .ldf和.mdf的文件附加数据库的sql语句_MsSql_
- 请问在mssql“SQL事件探查器”里表格的标题,如CPU,Read,Write,Duration,SPID.........的解释_MsSql_
- mssql server 存储过程里,bulk insert table from '路径+文件',路径固定,文件名不固定的实现方法_MsSql_
- 收缩后对数据库的使用有影响吗?_MsSql_
- 非常详细的SQL--JOIN之完全用法_MsSql_
- 使用 GUID 值来作为数据库行标识讲解_MsSql_
