如
我要查询 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效率高多了
您可能感兴趣的文章: 浅谈MySQL中优化sql语句查询常用的30种方法 SQLServer 优化SQL语句 in 和not in的替代方案 SQL SERVER 的SQL语句优化方式小结 MySQL SQL语句优化的10条建议 Mysql查询最近一条记录的sql语句(优化篇) SQL Server中的SQL语句优化与效率问题 常用SQL语句优化技巧总结【经典】 SQL语句优化方法30例(推荐) 如何优化SQL语句的心得浅谈 你真的知道怎么优化SQL吗
查看更多关于sql语句优化之用EXISTS替代IN、用NOTEXISTS替代NOTIN的语句的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://www.haodehen.cn/did34142