当前位置:首页 > 技术分析 > 正文内容

SQL执行顺序(SqlServer)

ruisui8811小时前技术分析1

学习SQL这么久,如果突然有人问你SQL的执行顺是怎么样的?是不是很多人会觉得C#、JavaScript都是根据编程顺序来处理的,那么SQL也是根据编程顺序来执行的吗?

No. SQL不同于其它编程语言,在SQL语言中尽管第一个出现是的是Select语句,但是其实数据库第一个被处理的语句是From子句,我们了解了SQL的执行顺序,那么对应我们后边需要学习的Linq会有一定的帮助,我们在最后的时候举一个例子来讲解下。

(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>

可以看到总的有十一个步骤,每一步的操作都会产生一个虚拟表,该虚拟表作为下一个处理的输入,我们来看下执行顺序:

(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,并返回给查询用户

举例说明:

在学生成绩表中 (Grade), 把 "姓名"内容不为空的记录按照 "姓名" 分组, 并且筛选分组结果, 选出 "总成绩" 大于 600 分的并按照总成绩进行从大到小排序
标准顺序的 SQL 语句为:
select 姓名, max(总成绩) as max总成绩
from Grade
where 姓名 is not null
group by 姓名
having max(总成绩) > 600
order by max总成绩 desc
在上面的示例中 SQL 语句的执行顺序如下:
(1). 首先执行 FROM 子句, 从 Grade 表组装数据源的数据
(2). 执行 WHERE 子句, 筛选 Grade 表中姓名不为空的数据
(3). 执行 GROUP BY 子句, 把 Grade 表按 "姓名" 列进行分组
(4). 计算 max() 聚集函数, 按 "总成绩" 求出总成绩中最大的一些数值
(5). 执行 HAVING 子句, 筛选课程的总成绩大于 600 分的.
(7). 执行 ORDER BY 子句, 把最后的结果按 "Max 成绩" 进行排序.


注:这边因为涉及到了数据统计的WITH CUBE|ROLLUP,我们也大概了解下

CUBE\ROLLUP可以对查询的数据进行汇总。

区别:CUBE会对所有的分组字段进行统计,ROLLUP不会对Group By第一个字段进行统计


例子:

SQL

Select * from Users Where Id=16

Linq

from a in Users
where a.Id ==16
Select a

我们通过上述的Linq的例子是否就可以看出来,Linq直接就是按照SQL的执行顺序进行书写语句的。

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/4518.html

标签: group by desc
分享给朋友:

“SQL执行顺序(SqlServer)” 的相关文章

抖音 Android 性能优化系列:启动优化实践

启动性能是 APP 使用体验的门面,启动过程耗时较长很可能使用户削减使用 APP 的兴趣,抖音通过对启动性能做劣化实验也验证了其对于业务指标有显著影响。抖音有数亿的日活,启动耗时几百毫秒的增长就可能带来成千上万用户的留存缩减,因此,启动性能的优化成为了抖音 Android 基础技术团队在体验优化方向...

2024最新版:前端性能优化方案汇总

前端训练营:1v1私教,终身辅导计划,帮你拿到满意的 offer。 已帮助数百位同学拿到了中大厂 offer。欢迎来撩~~~~~~~~Hello,大家好,我是 Sunday。前端性能优化一直是很多同学非常关注的问题,在日常的面试中也是经常会被问到的点。所以今天咱们就花一点时间来了解一下2024最新的...

你感动了吗?佳能超规格镜头 RF 24-105mm F2.8深度测评

如果要你选一支用作多题材创作的挂机镜头,那我相信很多人会选择24-105mm这个焦段的镜头。作为一支可以实现从广角到长焦的变焦镜头,24-105mm有着丰富的焦段选择。只是基于镜头体积以及光学结构上的限制,此前的24-105mm镜头只能恒定在F4的光圈。而佳能打破了这一限制,将实用焦段和恒定光圈完美...

前端路由简介以及vue-router实现原理

作者:muwoo 来源:https://zhuanlan.zhihu.com/p/37730038后端路由简介路由这个概念最先是后端出现的。在以前用模板引擎开发页面时,经常会看到这样http://www.xxx.com/login 大致流程可以看成这样:浏览器发出请求服务器监听到80 端口(或443...

Vue实现动态路由

通常我们在vue项目中都是前端配置好路由的,但在一些项目中我们可能会遇到权限控制,这样我们就涉及到动态路由的设置了。动态路由设置一般有两种:(1)、简单的角色路由设置: 比如只涉及到管理员和普通用户的权限。通常直接在前端进行简单的角色权限设置(2)、复杂的路由权限设置: 比如OA系统、多种角色的权限...

基于Spring Cloud+VUE的多租户小程序商城源码「快速二开可商用」

一、系统介绍JooLun平台是一个专注微信快速二开系统研发的平台,采用Java语言开发,使用的是最新微服务前后端分离技术,目前有公众号和小程序商城两个版本,有公众号后台管理、小程序商城。基于Spring Cloud微服务+VUE实现的核心框架多租户小程序商城源码,核心框架采用SpringBoot2+...