SQL 查询语句的子句的执行顺序

书写顺序: SELECT → FROM → WHERE → GROUP BY → HAVING → ORDER BY → LIMIT

执行顺序:

FROM + JOIN + ON

WHERE

GROUP BY

HAVING

SELECT

DISTINCT

ORDER BY

LIMIT

例子:

sql 复制代码
SELECT 
  category,  -- 步骤5:选择要返回的列
  AVG(price) AS avg_price 
FROM product  -- 步骤1:确定数据源
JOIN category c ON product.cid = c.id  -- 步骤1:关联表,指定条件
WHERE price > 50  -- 步骤2:过滤原始行(价格>50)
GROUP BY category  -- 步骤3:按类别分组
HAVING avg_price > 100  -- 步骤4:过滤分组(平均价格>100)
ORDER BY avg_price DESC  -- 步骤7:按平均价格降序
LIMIT 5;  -- 步骤8:只返回前5组
  1. FROM + JOIN + ON: 首先确定查询的数据源(表),并通过 JOIN 关联多个表,ON指定关联条件(先有数据来源,才能后续处理)。

  2. WHERE: 对关联后的原始数据行进行过滤,移除不满足条件的行(此时还未分组,不能用聚合函数)

  3. GROUP BY: 将 WHERE过滤后的行按指定列分组(相同值的行归为一组)。

  4. HAVING: 对 GROUP BY 分组后的结果进行过滤,只保留满足条件的分组(可使用聚合函数,如 HAVING COUNT(*) > 10)。

  5. SELECT: 从前面处理后的结果中,选择需要返回的列(或聚合函数结果),此时才确定最终输出的字段。

  6. DISTINCT: 对 SELECT 后的结果去除重复行(如果使用了 DISTINCT)。

  7. ORDER BY: 对 SELECT 后的结果按指定列排序(升序 / 降序)。

  8. LIMIT: 最后限制返回的行数(如分页查询取前 10 行)。

相关推荐
KmSH8umpK9 小时前
Redis分布式锁进阶第十二篇
数据库·redis·分布式
hERS EOUS9 小时前
MySQL 函数
数据库·mysql
gQ85v10Db9 小时前
Redis分布式锁进阶第十六篇:番外高阶避坑篇 + 隐性埋点锁故障深挖 + 疑难杂症终极兜底方案
数据库·redis·分布式
S1998_1997111609•X9 小时前
论恶意注入污染蜜罐进程函数值取仺⺋以集团犯罪获取数据爬虫的轮系依据
网络·数据库·爬虫·网络协议·百度
许彰午9 小时前
# 从OOM到根治的完整过程——导出大数据的应急、根因分析与游标方案
java·大数据·数据库·系统架构
eLIN TECE10 小时前
nacos2.3.0 接入pgsql或其他数据库
数据库
曾几何时`10 小时前
MySQL(七)索引
数据库·mysql
KmSH8umpK10 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第九篇
数据库·redis·分布式
悠悠1213810 小时前
一条 SQL 从敲下回车,到在 MySQL 里“跑完一生”,中间到底经历了啥?
数据库·sql·mysql
秋910 小时前
MySQL 9.7.0 使用详解:新特性、实战与避坑指南
android·数据库·mysql