SQL书写顺序与执行顺序

1、书写顺序

sql语句的书写顺序:

java 复制代码
select >> from >> where >> group by >> having >> order by >> limit
java 复制代码
select [ALL | DISTINCT | DISTINCTROW | TOP] 字段
from 表
[inner join  right join | left join 表2]
[on 连接条件]
[where 条件]
[group by 分组规则]
[having 分组条件]
[order by 排序规则]
[limit 分页规则]

注意:

  1. select和from是必须的;

  2. where和having不能同时使用;

  3. having和group by联合使用;

2、执行顺序

java 复制代码
from > on > join > where > group by > having > select > distinct > order by > limit

注意:虽然select在having后执行,但是mysql中仍然可以在having中使用select语句定义的别名

1.FORM:选择from后面跟的表,产生虚拟表1。

2.ON:ON是JOIN的连接条件,符合连接条件的行会被记录在虚拟表2中。

3.JOIN:如果指定了LEFT JOIN,那么保留表中未匹配的行就会作为外部行添加到虚拟表2中,产生虚拟表3。如果有多个JOIN链接,会重复执行步骤1~3,直到处理完所有表。

4.WHERE:对虚拟表3进行WHERE条件过滤,符合条件的记录会被插入到虚拟表4中。

5.GROUP BY:根据GROUP BY子句中的列,对虚拟表2中的记录进行分组操作,产生虚拟表5。

6.HAVING:对虚拟表5进行HAVING过滤,符合条件的记录会被插入到虚拟表6中。

7.SELECT:SELECT到一步才执行,选择指定的列,插入到虚拟表7中。

8.UNION:UNION连接的两个SELECT查询语句,会重复执行步骤1~7,产生两个虚拟表7,UNION会将这些记录合并到虚拟表8中。

9.ORDER BY: 将虚拟表8中的记录进行排序,虚拟表9。

10.LIMIT:取出指定行的记录,返回结果集。

相关推荐
数据库小组7 小时前
MySQL 删库后怎么恢复?binlog2sql 之外,NineData 还能做什么
数据库·sql·mysql·安全·数据·ninedata·删库
competes8 小时前
慈善基金投资底层逻辑应用 顶层代码低代码配置平台开发结构方式数据存储模块
java·开发语言·数据库·windows·sql
0xDevNull9 小时前
MySQL 别名(Alias)指南:从入门到避坑
java·数据库·sql
正在走向自律17 小时前
KingbaseES 基础 SQL 语法与日常运维实操手册
运维·数据库·sql·kingbasees
AKA__Zas17 小时前
初识 事务
java·开发语言·数据库·sql
xyyaihxl17 小时前
【SQL技术】不同数据库引擎 SQL 优化方案剖析
数据库·sql
℡終嚸♂6801 天前
FlowiseAI 任意文件上传 CTF Writeup
sql·web安全
与衫1 天前
[特殊字符] 解决 DataHub 无法解析复杂 SQL 血缘的问题(gsp-datahub-sidecar 实测)
数据库·sql
以神为界2 天前
数据库入门全指南:从基础概念到实操操作(含SQL+Navicat)
网络·数据库·sql·安全
Elastic 中国社区官方博客2 天前
Elasticsearch:快速近似 ES|QL - 第二部分
大数据·数据库·sql·elasticsearch·搜索引擎·全文检索