where条件放在子SQL语句中是否查询速度更快?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了where条件放在子SQL语句中是否查询速度更快?相关的知识,希望对你有一定的参考价值。

1、具体的语句得具体分析
2、总体你的想法是对的
3、跟开发是一样的。
4、直接的相当于全局,子句可以理解为局部
这相当于全局变量和局部变量一样,局部的(子句),比较省内存;如果全局的使用比较多,那全局的会好一点。

海枫科技
参考技术A 如果子查询不能明显降低数据量,尽快不使用子查询本回答被提问者采纳 参考技术B SQL Select语句完整的执行顺序:
1、from子句组装来自不同数据源的数据;
2、where子句基于指定的条件对记录行进行筛选;
3、group by子句将数据划分为多个分组;
4、使用聚集函数进行计算;
5、使用having子句筛选分组;
6、计算所有的表达式;
7、使用order by对结果集进行排序
参考技术C 不是。。。
你查下执行计划

MyBatis框架中的条件查询!关键字exists用法的详细解析

exists用法

  • exists:

    • 如果括号内子查询语句返回结果不为空,说明where条件成立,就会执行主SQL语句
    • 如果括号内子查询语句返回结果为空,说明where条件不成立,就不会执行主SQL语句
  • not exists: 与exists相反

    • 如果括号内子查询语句结果为空,说明表示where条件成立,就会执行主SQL语句
    • 如果括号内子查询语句结果不为空,说明表示where条件不成立,就不会执行主SQL语句

      • exists与in的区别:

        • in只能返回一个字段值
        • exists强调是否返回结果集,不要求知道返回什么,exists允许返回多个字段
      • exists的效率一般优于in:

        • 使用exists,Oracle首先会检查主查询,然后运行子查询直到找到第一个匹配项
        • 使用in子查询时,首先会执行子查询,并将获得的结果列表放在一个加了索引的临时表中
      • exists的效率优于distinct:

        • 当提交一对多表信息查询时,就可以避免在select中使用distinct
        • 因为RDBMS核心模块将在子查询的条件一旦满足后,立即返回结果,所以自带去重.以下两组SQL语句等价:

          SELECT distinct dept_no, dept_name from dept D, EMP E WHERE D.dept_no = E.dept_no;
          SELECT dept_no, dept_name from dept D WHERE EXISTS (SELECT 1 from emp E WHERE E.dept_no = D.dept_no);
      • exists适合外表的结果集小的情况
      • in适合内外表都很大的情况

        使用示例

  • exists:

    SELECT ID,NAME FROM A WHERE 
    EXISTS(SELECT * FROM B WHERE A.ID = B.AID)
  • SQL语句分解:

    SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID=1) 
    --->SELECT * FROM B WHERE B.AID=1有值返回TRUE所以有数据 
    
    SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID=2) 
    --->SELECT * FROM B WHERE B.AID=2有值返回TRUE所以有数据 
    
    SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID=3) 
    --->SELECT * FROM B WHERE B.AID=3无值返回TRUE所以没有数据 
  • 上面SQL语句等价于:

    SELECT id, name from A WHERE id in (select aid from B)

    总结

  • SQL中in, not in, exists, not exists的区别:

    • in:

      • 确定给定的值是否与子查询或者列表中的值匹配
      • in关键字选择与列表中任意一个值匹配的行
      • in关键字之后的项目必须用逗号隔开,并且括在括号中
    • not in:

      • 通过not in关键字引入的子查询也返回一列零值或更多值
    • exists:

      • 指定一个子查询,检测行的存在
      • 相当于两个集合的交集
      • exists后面可以是整句的查询语句 ,in后面只能是单列查询语句
    • not exists:

      • 相当于两个集合的差集
    • exists和not exists返回的结果类型是Boolean:

      • 如果子查询包含行:

        • exists返回TRUE
        • not exists返回FALSE

以上是关于where条件放在子SQL语句中是否查询速度更快?的主要内容,如果未能解决你的问题,请参考以下文章

MYSQL子查询

sql语句中where条件的嵌套子查询性能

SQL 查询条件放在LEFT OUTER JOIN 的ON语句后与放在WHERE中的区别

SQL(高级查询)

mysql SQL语句如何将sum()放在where后面做条件怎么写呢?

MyBatis框架中的条件查询!关键字exists用法的详细解析