当前位置:网站首页>零基础自学SQL课程 | SQL语句语法顺序与执行顺序
零基础自学SQL课程 | SQL语句语法顺序与执行顺序
2022-06-24 07:58:00 【喵宁一】
大家好,我是宁一。
今天讲解SQL教程第17课:SQL语句书写顺序与执行顺序。
SQL 语句的书写顺序与执行顺序不是一致的,我们通过这节课来搞清楚。
1、书写顺序
语句书写顺序很重要,顺序不对会报错的。
我们前面的课程已经学过SELECT、WHERE、ORDER BY、LIMIT、JOIN、UNION、GROUP BY、HAVING语句用法。
如果这些语句在SQL中同时存在,书写顺序是这样的:
SELECT <字段名>
FROM <表名>
JOIN <表名>
ON <连接条件>
WHERE <筛选条件>
GROUP BY <字段名>
HAVING <筛选条件>
UNION
ORDER BY <字段名>
LIMIT <限制行数>;看着比较复杂,不过我们不需要特意去背,多进行一些实战练习,自然而然就记住了。
2、执行顺序
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:取出指定行的记录,返回结果集。
3、总结:
书写顺序:SELECT -> FROM -> JOIN -> ON -> WHERE -> GROUP BY -> HAVING -> UNION -> ORDER BY ->LIMIT
执行顺序:FROM -> ON -> JOIN -> WHERE -> GROUP BY -> HAVING -> SELECT -> UNION -> ORDER BY ->LIMIT
4、需要注意的地方:
1.SELECT语句总是写在最前面,但在大部分语句之后才执行。所以在SQL语句中,我们不能在WHERE、GROUP BY、 HAVING语句中使用在 SELECT 中设定的别名。
但是MYSQL有个特性,在GROUP BY、 HAVING语句中,可以使用 SELECT 中设定的别名。这不是因为MYSQL中会提前执行SELECT,而是因为在GROUP BY这一步返回了游标,大家了解一下就好。
2.无论是书写顺序,还是执行顺序,UNION 都是排在 ORDER BY 前面的。SQL语句会将所有UNION 段合并后,再进行排序。
我们本节课程总结了sql语句的书写顺序和执行顺序,理解这些有助于我们对sql语句进行优化,提高我们的数据库理解能力。建立我们后面编写复杂SQL的基础。
如果能掌握SQL语句书写顺序和执行顺序,那么恭喜你,已经可以解决大部分的SQL问题了。
下节课我们会开始讲子查询,理解了这节课的内容,后面编写更复杂的SQL也就得心应手了~
点击关注,更新课程第一时间通知哦~
边栏推荐
- Idea another line shortcut
- 荐书丨《好奇心的秘密》:一个针尖上可以站多少跳舞的小天使?
- 【gdb调试工具】| 如何在多线程、多进程以及正在运行的程序下调试
- 从华为WeAutomate数字机器人论坛,看政企领域的“政务新智理”
- MYCAT read / write separation and MySQL master-slave synchronization
- MySQL - SQL statement
- 华为路由器:ipsec技术
- 110. balanced binary tree recursive method
- Huawei Router: IPSec Technology
- 牛客网 十进制整数转十六进制字符串
猜你喜欢

The border problem after the focus of input

MySQL | view notes on Master Kong MySQL from introduction to advanced

cookie加密 4 rpc方法确定cookie加密

leetcode——错误的集合

A tip to read on Medium for free

How to configure environment variables and distinguish environment packaging for multi terminal project of uniapp development

Numpy numpy中的np.c_和np.r_详解

【LeetCode】541. 反转字符串 II

【ES6闯关】Promise堪比原生的自定义封装(万字)

【LeetCode】387. 字符串中的第一个唯一字符
随机推荐
目标检测系列——Fast R-CNN
The border problem after the focus of input
Recommendation - Secret of curiosity: how many dancing angels can stand on the tip of a needle?
The printed object is [object object]. Solution
P6698-[BalticOI 2020 Day2]病毒【AC自动机,dp,SPFA】
[MySQL from introduction to mastery] [advanced part] (I) character set modification and underlying principle
1844. replace all numbers with characters
Pytoch read data set (two modes: typical data set and user-defined data set)
数云发布2022美妆行业全域消费者数字化经营白皮书:全域增长破解营销难题
[redis realize Secondary killing Business ①] Overview of Secondary killing Process | Basic Business Realization
2138. splitting a string into groups of length k
1704. judge whether the two halves of a string are similar
Data middle office: the data middle office practice scheme of Minsheng Bank
RISC-V架构下 FPU Context 的动态保存和恢复
Pytorch读入据集(典型数据集及自定义数据集两种模式)
Code written by mysql, data addition, deletion, query and modification, etc
threejs辉光通道01(UnrealBloomPass && layers)
Every (), map (), forearch () methods. There are objects in the array
学习太极创客 — ESP8226 (十二)ESP8266 多任务处理
2022-06-23:给定一个非负数组,任意选择数字,使累加和最大且为7的倍数,返回最大累加和。 n比较大,10的5次方。 来自美团。3.26笔试。