当前位置: 首页 > article >正文

MySQL的SQL书写顺序和执行顺序

老是忘记执行顺序,记录一下:

1. SQL语句的书写顺序

书写顺序通常是我们编写SQL查询时的顺序,主要包括以下关键字:

  1. SELECT:选择要查询的字段。
  2. FROM:指定数据来源表。
  3. JOIN(可选):对表进行连接。
  4. WHERE(可选):设定行过滤条件。
  5. GROUP BY(可选):设定分组依据。
  6. HAVING(可选):对分组后的数据进一步过滤。
  7. ORDER BY(可选):设定排序。
  8. LIMIT(可选):限制返回的记录数。

书写顺序示例:

SELECT district, SUM(population) 
FROM PopTbl WHERE population > 1000 
GROUP BY district 
HAVING SUM(population) > 5000 
ORDER BY district LIMIT 10;

2. SQL语句的执行顺序

SQL的执行顺序,通常遵循以下逻辑步骤:

  1. FROM:确定查询数据的来源表。
  2. JOIN:如果有多表连接,则执行连接操作。
  3. WHERE:对记录进行行级过滤。
  4. GROUP BY:根据指定的列进行分组。
  5. HAVING:对分组后的数据进行过滤。
  6. SELECT:选择需要输出的字段和聚合结果。
  7. ORDER BY:对结果进行排序。
  8. LIMIT:限制返回的记录数量。

执行顺序比书写顺序更重要,因为它决定了SQL查询的逻辑流程。

示例说明执行顺序

以下示例演示了SQL查询的执行过程:

SELECT district, SUM(population) AS total_population 
FROM PopTbl 
WHERE population > 1000 
GROUP BY district 
HAVING total_population > 5000 
ORDER BY total_population DESC LIMIT 10;
执行过程逐步解释:
  1. FROM:从 PopTbl 表中获取所有记录。
  2. WHERE:应用 population > 1000 的过滤条件,筛选出人口大于1000的记录。
  3. GROUP BY:根据 district 列将筛选后的记录进行分组。
  4. HAVING:对分组结果应用 total_population > 5000 的条件,过滤掉不符合条件的分组。
  5. SELECT:选择 districtSUM(population) 结果(并将其命名为 total_population)。
  6. ORDER BY:按照 total_population 降序排序。
  7. LIMIT:限制返回的结果数为10条。

这样,MySQL会按照执行顺序进行逐步处理,最终返回满足条件的、按总人口降序排列的前10个地区和对应人口总数。


http://www.kler.cn/a/391100.html

相关文章:

  • 用vscode编写verilog时,如何有信号定义提示、信号定义跳转(go to definition)、模块跳转这些功能
  • leetcode hot100【LeetCode 114.二叉树展开为链表】java实现
  • 基于非时空的离身与反身智能
  • libcurl.net入门使用
  • 网页版五子棋——对战模块(服务器端开发②)
  • 11Java面向对象高级(篇2,Java程序的核心套路!!!!)
  • AI与OCR:数字档案馆图像扫描与文字识别技术实现与项目案例
  • 【SDL Trados Studio】sdltm格式转excel
  • HTTP Cookie深入解析:Web会话追踪
  • 在 Service Worker 中caches.put() 和 caches.add()/caches.addAll() 方法他们之间的区别
  • 校园服务平台小程序ssm+论文源码调试讲解
  • 力扣 653. 两数之和 IV 二叉树/binary-tree two-sum IV
  • Python 如何根据给定模型计算权值
  • Scala中的case class
  • 在配置环境变量之后使用Maven报错 : mvn : 无法将“mvn”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。
  • 【PowerHarmony】电鸿蒙学习记录-准备工作
  • HarmonyOS开发 API 13发布首个Beta版本,解决了哪些问题?
  • java/SpingBoot
  • 数据仓库还是数据集市?这俩怎么选?
  • 图文组合-pytorch实现
  • 使用 Regex 在 Java 中使用 Logstash LogBack 屏蔽日志
  • 群控系统服务端开发模式-应用开发-前端个人资料开发
  • 基于51单片机俄罗斯方块游戏—可暂停
  • 一文了解git TAG
  • 通过scrapy和Django登录、爬取和持久化数据
  • 如何使用 SSH 连接并管理你的 WordPress 网站