SQL语句顺序和执行优先级

古城微笑少年丶 2022-09-10 05:08 242阅读 0赞

SQL 顺序

  1. SELECT DISTINCT column, AGG_FUNC(column_or_expression),
  2. FROM mytable
  3. JOIN another_table
  4. ON mytable.column = another_table.column
  5. WHERE constraint_expression
  6. GROUP BY column
  7. HAVING constraint_expression
  8. ORDER BY column ASC/DESC
  9. LIMIT count OFFSET COUNT;

SQL 的解析顺序

  1. 1. FROM JOINs
  2. FROM JOIN会第一个执行,确定一个整体的数据范围. 如果要JOIN不同表,可能会生成一个临时Table来用于 下面的过程。总之第一步可以简单理解为确定一个数据源表(含临时表)
  3. 2. WHERE
  4. 我们确定了数据来源 WHERE 语句就将在这个数据源中按要求进行数据筛选,并丢弃不符合要求的数据行,所有的筛选col属性 只能来自FROM圈定的表. AS别名还不能在这个阶段使用,因为可能别名是一个还没执行的表达式
  5. 3. GROUP BY
  6. 如果你用了 GROUP BY 分组,那GROUP BY 将对之前的数据进行分组,统计等,并将是结果集缩小为分组数.这意味着 其他的数据在分组后丢弃.
  7. 4. HAVING
  8. 如果你用了 GROUP BY 分组, HAVING 会在分组完成后对结果集再次筛选。AS别名也不能在这个阶段使用.
  9. 5. SELECT
  10. 确定结果之后,SELECT用来对结果col简单筛选或计算,决定输出什么数据.
  11. 6. DISTINCT
  12. 如果数据行有重复DISTINCT 将负责排重.
  13. 7. ORDER BY
  14. 在结果集确定的情况下,ORDER BY 对结果做排序。因为SELECT中的表达式已经执行完了。此时可以用AS别名.
  15. 8. LIMIT / OFFSET
  16. 最后 LIMIT OFFSET 从排序的结果中截取部分数据.

发表评论

表情:
评论列表 (有 0 条评论,242人围观)

还没有评论,来说两句吧...

相关阅读

    相关 SQL语句执行顺序

    ql和mysql执行顺序,发现内部机制是一样的。最大区别是在别名的引用上。  一、sql执行顺序  (1)from  (3) join  (2) on 

    相关 SQL语句执行顺序

    查询语句中select from where group by having order by的执行顺序   1.查询中用到的关键词主要包含六个,并且他们的书写顺序依次为 

    相关 SQL语句执行顺序

    SQL Select语句完整的执行顺序:  1、from子句组装来自不同数据源的数据;  2、where子句基于指定的条件对记录行进行筛选;  3、group by子句将