mysql 执行顺序以及不允许使用列的别名作为查询条件

本文详细阐述了MySQL查询语句的执行流程,包括FROM、ON、JOIN、WHERE、GROUP BY、WITH、HAVING、SELECT、DISTINCT、ORDER BY和LIMIT的步骤,并指出常见SQL语法陷阱。理解这些步骤有助于优化查询性能和避免错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

myql的执行顺序


一条SQL会经过这11步的,中间的每一步都会生成一张虚拟表,后面的步骤都是在上一张虚拟表中进行筛选与查询的

  1. from
  2. on
  3. join
  4. where
  5. group by
  6. with
  7. having
  8. select
  9. distinct
  10. order by
  11. limit

例如:

select col+1 as a from table where a>100;这样的sql在执行时会报错。

列表别名可以在 GROUP BY, ORDER BY, HAVING中被引用,而标准的SQL禁止在where中被引用,因为where语句执行在先。
所以可以用子查询的方式代替

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值