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

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.mrgr.cn/news/68532.html

相关文章:

  • cordova 离线打包Android -Linux
  • Permissions 0755 for ‘/etc/ssh/ssh_host_rsa_key‘ are too open.问题解决
  • 【Java SE语法】抽象类(abstract class)和接口(interface)有什么异同?
  • 第08章 排序ORDER BY
  • 大厂面试真题-如果使用guava limiter实现实例级别的缓存
  • HTMLCSS:爱上班的猫咪
  • XHCI 1.2b 规范摘要(14)
  • 用户裂变数据分析
  • Rust常用数据结构教程 序列
  • 2024年11月8日Github流行趋势
  • AI 大模型如何重塑软件开发:从代码生成到未来愿景
  • MySQL 按日查询数据
  • C++静态成员函数
  • 【Ant Design Pro】框架思维导图
  • 面试题:Spring(一)
  • 技术复杂性导致估算不准确?5大对策
  • 鸿蒙进阶篇-网格布局 Grid/GridItem(二)
  • clickhouse自增id的处理
  • Nginx独立项目相关配置说明
  • 时间管理应用(可复制源码)
  • uniapp 整合 OpenLayers - 测距测面
  • Linux的基本指令(一)
  • Vue 组件通信-自定义事件(七)
  • AI芯片:推动高性能计算场景的关键力量
  • etherlab更新了一版IGH1.6.5
  • LeetCode 234.回文链表