SQL执行步骤的具体分析
作者:牧师-Panda 时间:2024-01-17 15:47:54
SQL执行步骤的具体分析
先来看执行语句的顺序
(8)select (9)distinct A (1)from Ta (3)join Tb
(2)on XXX (4)where XXX (5)group by XXX (6)with
{cube|roll up} (7)having XXX (10)order by XXX (11)limit XXX
接着我们看一下具体分析查询处理的各个阶段:
FROM 对from子句中的左表和右表执行笛卡尔集,产生虚拟表VT1
ON 对虚拟表VT1进行on筛选,只有那些符合join condition的行才 * 入虚拟表VT2中
JOIN 如果指定了outer join,那么保留表中未匹配的行作为外部行添加到虚拟表VT2中,产生虚拟表VT3。如果from子句包含两个以上的表,则对上一个连接生成的结果表中VT3和下一个表重复执行步骤1~步骤3,直到处理完所有的表为止。
WHERE 对虚拟表VT3进行where过滤条件,只有符合条件的才 * 入到虚拟表VT4中。
GROUP BY 根据group by子句中的列,对VT4中的记录进行分组操作,产生VT5.
CUBE|ROLL UP 对表VT5进行CUBE或者ROLLUP操作,产生表VT6.
HAVING 对虚拟表VT6应用having过滤器,只有符合条件的记录才会 * 入到虚拟表VT7中
SELECT 第二次执行select操作,选择指定的列,插入到虚拟表VT8中。
DISTINCT 去除重复数据,产生虚拟表VT9。
ORDER BY 将虚拟表VT9中的记录按照指定的要求进行排序操作,产生虚拟表VT10
LIMIT 取出指定行的记录,产生虚拟表VT11,并返回给查询用户
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
来源:https://my.oschina.net/hunglish/blog/1239916
标签:SQL,执行步骤


猜你喜欢
JavaScript 图片变换效果(ie only)
2010-01-20 12:40:00

SQL Server 总结复习 (二)
2024-01-22 23:14:50
Python实现多线程抓取妹子图
2022-10-02 15:39:25
教你一步步实现一个简易promise
2024-04-26 17:11:37
Apache+php+mysql在windows下的安装与配置(图文)第1/2页
2024-05-11 09:25:34

Python实现EXCEL表格的排序功能示例
2021-05-17 20:50:11

人脸识别具体案例(李智恩)
2023-05-18 22:32:55

python 实现读取一个excel多个sheet表并合并的方法
2023-06-25 20:11:51
django跳转页面传参的实现
2022-01-23 00:56:55
pandas DataFrame实现几列数据合并成为新的一列方法
2021-05-22 01:36:00

Go中使用单调时钟获得准确的时间间隔问题
2024-05-22 10:14:19

如何用python多次调用exe文件运行不同的结果
2023-07-08 03:01:24
python正则表达式re.match()匹配多个字符方法的实现
2023-07-30 08:25:16
vue使用v-for实现hover点击效果
2024-05-02 17:09:03

使用sublime text3搭建Python编辑环境的实现
2023-01-20 21:01:56

SQL 查询连续登录的用户情况
2024-01-29 01:27:18

mysql登录报错提示:ERROR 1045 (28000)的解决方法
2024-01-24 04:54:01
python实现点对点聊天程序
2023-10-27 11:42:02
python中通过pip安装库文件时出现“EnvironmentError: [WinError 5] 拒绝访问”的问题及解决方案
2023-08-29 20:25:40
java实现连接mysql数据库单元测试查询数据的实例代码
2024-01-26 12:38:47
