SQL语句的解析顺序
简单的说一个sql语句是按照如下的顺序解析的:
1. FROM FROM后面的表标识了这条语句要查询的数据源。和一些子句如,(1-J1)笛卡尔积,(1-J2)ON过滤,(1-J3)添加外部列,所要应用的对象。FROM过程之后会生成一个虚拟表VT1。
(1-J1)笛卡尔积 这个步骤会计算两个相关联表的笛卡尔积(CROSS JOIN) ,生成虚拟表VT1-J1。
(1-J2)ON过滤 这个步骤基于虚拟表VT1-J1这一个虚拟表进行过滤,过滤出所有满足ON 谓词条件的列,生成虚拟表VT1-J2。
(1-J3)添加外部行 如果使用了外连接,保留表中的不符合ON条件的列也会被加入到VT1-J2中,作为外部行,生成虚拟表VT1-J3。
2. WHERE 对VT1过程中生成的临时表进行过滤,满足where子句的列被插入到VT2表中。
3. GROUP BY 这个子句会把VT2中生成的表按照GROUP BY中的列进行分组。生成VT3表。
4. HAVING 这个子句对VT3表中的不同的组进行过滤,满足HAVING条件的子句被加入到VT4表中。
5. SELECT 这个子句对SELECT子句中的元素进行处理,生成VT5表。
(5-1)计算表达式 计算SELECT 子句中的表达式,生成VT5-1
(5-2)DISTINCT 寻找VT5-1中的重复列,并删掉,生成VT5-2
(5-3)TOP 从ORDER BY子句定义的结果中,筛选出符合条件的列。生成VT5-3表
ORDER BY 从VT5-3中的表中,根据ORDER BY 子句的条件对结果进行排序,生成VC6表。
分享到:
相关推荐
项目中已使用的一个比较简单的SQL语句查询字段解析工具类
讲解sql SQL 语句解析适用于初学者
用SQL语法,当然只能用简单的条件查询咯,不过这个用起比较简单,容易上手
通过解析sql语句获取表血缘关系
sql语句分析,主要用于dug模式下打印出来的sql分析,自动对sql语句进行解析,对查询条件、字段赋值进行准确的赋值,非常实用的一款工具。 操作非常简单: 1、copy打印出来的sql 2、点击sql分析,就得到你想要的...
适用场景:生产环境从sql日志获取可执行sql语句 使用方法:从日志中获取完整的sql片段(可以前后多复制一部分,确保准确性),打开html文件,粘贴到输入框中点击解析sql,获得可执行的sql
SQL语句解析java包,含源代码: SELECT ANTIQUEOWNERS.OWNERLASTNAME, ANTIQUEOWNERS.OWNERFIRSTNAME FROM ANTIQUEOWNERS, ANTIQUES WHERE ANTIQUES.BUYERID = ANTIQUEOWNERS.OWNERID AND ANTIQUES.ITEM = 'Chair'; ...
SQL语句大全,SQL语句大全,SQL语句大全,SQL语句大全,SQL语句大全
数据库sql语句解析系统.pdf
在数据库中硬解析是万恶之源,为大家提供一个查找并且定位oracle硬解析问题SQL语句脚本
对常用的sql语句和语法有详细的解答。对数据库入门和基础巩固有很大帮助
sql语句 SQL语句_使用C#解析SQL语句
Python SQL 结构处理类, 解释sql语句把sql语句解析成列,where列表..结构信息 根据需求把sql进行重整.
该文档详细介绍了一条sql从应用端提交开始,在数据库中的执行过程,sql的执行原理等,能够更有效的帮助你oracle数据库以及更有效的提高sql优化的能力。
SQL语句详解
由于最近需要做一些sql query性能提升的研究,因此研究了一下sql语句的解析过程;本文是我在看了各种资料后手机总结的,会详细的,一步一步的讲述一个sql语句的各个关键字的解析过程,欢迎大家互相学习
面向数据库性能的SQL语句解析与翻译.pdf
Linq 将生成SQL语句显示出来 用于检查linq解析出来的sql语句。 很适合新手学习
SQLtrack 数据库SQL语句监控解析,支持SQL语句追踪。解压直接运行
收集常用SQL语句。常用SQL语法解析,