手机
当前位置:查字典教程网 >编程开发 >mssql数据库 >sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句
sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句
摘要:在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下,使用EXISTS(或NOTEXISTS)通常将提高查询...

在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下,使用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的语句】相关文章:

SqlServer 2005 T-SQL Query 学习笔记(1)

SQL Server中的XML数据进行insert、update、delete操作实现代码

SqlServer 2005中使用row_number()在一个查询中删除重复记录

SQL Server 数据库管理常用的SQL和T-SQL语句

SQL Server2005 异地备份的多种方法

SQL Server 2008 新特性 总结复习(一)

SQL Server 2008的逻辑查询处理步骤

SQLServer基础语法实例应用(三)

SQL 提权 常用命令

sql server 2000 版本查询

精品推荐
分类导航