栏目分类:
子分类:
返回
终身学习网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
终身学习网 > IT > 软件开发 > 后端开发 > Java

零基础自学SQL课程 | SQL语句语法顺序与执行顺序

Java 更新时间:发布时间: 百科书网 趣学号

大家好,我是宁一。

今天讲解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也就得心应手了~

点击关注,更新课程第一时间通知哦~

转载请注明:文章转载自 www.051e.com
本文地址:http://www.051e.com/it/986579.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 ©2023-2025 051e.com

ICP备案号:京ICP备12030808号