sql语句定义和执行顺序
摘自《MySQL技术内幕:SQL编程》

sql语句定义的顺序

(1) SELECT (2)DISTINCT<select_list>
(3) FROM <left_table>
(4) <join_type> JOIN <right_table>
(5)         ON <join_condition>
(6) WHERE <where_condition>
(7) GROUP BY <group_by_list>
(8) WITH {CUBE|ROLLUP}
(9) HAVING <having_condition>
(10) ORDER BY <order_by_condition>
(11) LIMIT <limit_number>

sql语句执行顺序

(8) SELECT (9)DISTINCT<select_list>
(1) FROM <left_table>
(3) <join_type> JOIN <right_table>
(2)         ON <join_condition>
(4) WHERE <where_condition>
(5) GROUP BY <group_by_list>
(6) WITH {CUBE|ROLLUP}
(7) HAVING <having_condition>
(10) ORDER BY <order_by_list>
(11) LIMIT <limit_number>

可以看到,一共有十一个步骤,最先执行的是FROM操作,最后执行的是LIMIT操作。每个操作都会产生一个虚拟表,该虚拟表作为一个处理的输入,看下执行顺序:

(1) FROM:对FROM子句中的左表<left_table>和右表<right_table>执行笛卡儿积,产生虚拟表VT1;

(2) ON: 对虚拟表VT1进行ON筛选,只有那些符合<join_condition>的行才被插入虚拟表VT2;

(3) JOIN: 如果指定了OUTER JOIN(如LEFT OUTER JOIN、RIGHT OUTER JOIN),那么保留表中未匹配的行作为外部行添加到虚拟表VT2,产生虚拟表VT3。如果FROM子句包含两个以上的表,则对上一个连接生成的结果表VT3和下一个表重复执行步骤1~步骤3,直到处理完所有的表;

(4) WHERE: 对虚拟表VT3应用WHERE过滤条件,只有符合<where_condition>的记录才会被插入虚拟表VT4;

(5) GROUP By: 根据GROUP BY子句中的列,对VT4中的记录进行分组操作,产生VT5;

(6) CUBE|ROllUP: 对VT5进行CUBE或ROLLUP操作,产生表VT6;

(7) HAVING: 对虚拟表VT6应用HAVING过滤器,只有符合<having_condition>的记录才会被插入到VT7;

(8) SELECT: 第二次执行SELECT操作,选择指定的列,插入到虚拟表VT8中;

(9) DISTINCT: 去除重复,产生虚拟表VT9;

(10) ORDER BY: 将虚拟表VT9中的记录按照<order_by_list>进行排序操作,产生虚拟表VT10;

(11) LIMIT: 取出指定街行的记录,产生虚拟表VT11,并返回给查询用户

25、Sql语句执行顺序相关推荐

  1. mysql oracle 查询语句执行顺序_MySQL sql语句执行顺序

    (8)     DISTINCT (1)     FROM (3)      JOIN (2)     ON (4)     WHERE (5)     GROUP BY (6)     HAVING ...

  2. 【转】SQL 语句执行顺序

    From:http://www.jellythink.com/archives/924 Oracle-SQL语句执行原理和完整过程详解:https://wenku.baidu.com/view/398 ...

  3. SQL 语句执行顺序

    From:http://www.jellythink.com/archives/924 Oracle-SQL语句执行原理和完整过程详解:https://wenku.baidu.com/view/398 ...

  4. php语句执行顺序,sql语句执行顺序是什么

    sql语句执行顺序:1.最先执行from tab:2.where语句是对条件加以限定:3.分组语句[group by-- having]:4.聚合函数:5.select语句:6.order by排序语 ...

  5. mysql 执行顺序 SQL语句执行顺序分析

    最近在做一个数据库的大作业,算是复习了下MySql里面比较复杂的一些语句的用法,如Left Join之类的.在这里就不对具体语法进行记录了,希望能在以后经常用到,而不是隔好长时间用一次.在这里就记录下 ...

  6. 整理:sql server 中sql语句执行顺序

    原文地址为: 整理:sql server 中sql语句执行顺序 SQL Server 查询处理中的各个阶段(SQL执行顺序) SQL 不同于与其他编程语言的最明显特征是处理代码的顺序.在大数编程语言中 ...

  7. SQL Server 中SQL语句执行顺序

    SQL Server 中SQL语句执行顺序 我们需要对SQL语句的执行顺序了若指掌,才能更好的理解SQL. SQL 不同于与其他编程语言的最明显特征是处理代码的顺序. 在大数编程语言中,代码按编码顺序 ...

  8. mysql sql语句执行顺序

    mysql sql语句执行顺序 引言:作为一个程序猿.要想优化sql,首先要明白sql语句的执行顺序.同时防止该死的面试官问一些数据库专业的问题有必要知道这些 sql语句select语句查询顺序 (7 ...

  9. MySql的sql语句执行顺序

    MySql的sql语句执行顺序 FROM table1 left join table2 on 将table1和table2中的数据产生笛卡尔积,生成Temp1 JOIN table2 所以先是确定表 ...

最新文章

  1. TabBarItem图片不显示的原因
  2. [Python]网络爬虫(五):urllib2的使用细节与抓站技巧
  3. AI:人工智能实践六大场景(金融信用违约、反欺诈模型、客户偏好洞察、智能推荐、精准营销、客户流失管理)及其对应常用机器学习算法经验总结(不断更新)
  4. python控制电机_树莓派Python控制步进电机
  5. 顺序栈实现表达式求值(C语言实现)【栈】
  6. php parse url 反向,实现PHP中parse_url的逆运算http_build_url
  7. matlab磁铁模拟,用matlab-模拟环形磁铁的磁场分布
  8. Web常见前端面试题及答案
  9. DEA_Malmquist指数模型学习笔记
  10. 计算机打印字与印刷字的大小,字号与尺寸对表.doc
  11. excel两列数据对比找不同_快速找出表格中两列的不同项,事半功倍的方法记得收藏...
  12. 【转】RTF格式分析
  13. web前端设计与开发大作业(一)----黄山风景区
  14. 沁春教你怎么在家制作拿铁咖啡!
  15. 2021-02-24 bat 批处理教程
  16. u盘有声音但是不显示怎么办?u盘不显示解决方案
  17. 误差反向传播法实现手写数字识别(纯numpy实现)
  18. 在arm-linux上用gdb调试程序,出现“Program received signal SIGPIPE, Broken pipe”
  19. Linux:査看文件的详细信息
  20. Java中重写父类方法

热门文章

  1. ML之PLiR之Glmnet:利用Glmnet算法求解ElasticNet回归类型问题(实数值评分预测)
  2. Paper之DL之BP:《Understanding the difficulty of training deep feedforward neural networks》
  3. JAVA_OA管理系统(三):Spring参数注入
  4. [pymongo] pymongo.errors.CursorNotFound Exception
  5. linux明日命令(6):rm命令
  6. Python assert 断言
  7. Python函数篇(5)-装饰器及实例讲解
  8. bootstrap 列表--水平定义列表
  9. spring MVC配置详解
  10. C语言写的流氓关机程序及破解