最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-09 07:16:50
文档

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

sql语句优化之用EXISTS替代IN、用NOTEXISTS替代NOTIN的语句:在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下, 使用EXISTS(或NOT EXISTS)通常将提高查询的效率。在子查询中,NOT IN子句将执行一个内部的排序和合并。无论在哪种情况下,NOT IN都是最低效的 (因为它对子查询中的表执
推荐度:
导读sql语句优化之用EXISTS替代IN、用NOTEXISTS替代NOTIN的语句:在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下, 使用EXISTS(或NOT EXISTS)通常将提高查询的效率。在子查询中,NOT IN子句将执行一个内部的排序和合并。无论在哪种情况下,NOT IN都是最低效的 (因为它对子查询中的表执


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

    sql语句优化之用EXISTS替代IN、用NOTEXISTS替代NOTIN的语句:在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下, 使用EXISTS(或NOT EXISTS)通常将提高查询的效率。在子查询中,NOT IN子句将执行一个内部的排序和合并。无论在哪种情况下,NOT IN都是最低效的 (因为它对子查询中的表执
    推荐度:
    标签: in notin notexists
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top