主页 > 知识库 > sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句

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

热门标签:怎么在高德地图标注多个点 沈阳外呼系统有效果吗 百度地图标注信息怎么修改 AI智能云呼电话机器人怎么注册 福州外呼系统招商 温州语音外呼系统排名 电话机器人接口是什么样的 四川稳定外呼系统公司 商家地图标注图片
在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下, 使用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效率高多了 
您可能感兴趣的文章:
  • 浅谈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、用NOT EXISTS替代NOT IN的语句》,本文关键词  sql,语句,优化,之用,EXISTS,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句》相关的同类信息!
  • 本页收集关于sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句的相关信息资讯供网民参考!
  • 推荐文章