mysql语句执行顺序_Oracle优化:sql语句的执行顺序

理解 sql 语句的执行顺序对我们优化 sql 有很大的帮助,那么 sql 语句的执行顺序是怎样的呢,以一条简单的的语句做分析:

01e875ccafaec0dd18f9db21954f83b1.png

① 先执行 from 子句,明确数据的来源,从哪个表或哪个视图来查询

② 接着执行 where 子句,根据列出来的条件筛选数据

③ 然后执行 group by 子句,对数据进行分组

④ 再执行 having 子句,对分组后的数据进行筛选

⑤ 之后执行 select 子句,选择展示哪些数据列

⑥ 最后执行 order by 子句,对应最终的结果进行排序

如何 sql 语句中有表连接,那么会先执行连接的条件 on 子句再执行 join 子句。并且这部分的执行是在上述步骤的 ① 和 ② 之间就执行的。

这个步骤跟其他编程语言从上往下执行的顺序不太一样,但也是合乎情理的,相信也在广大读者的预料之中。虽然我们可能不知道数据库的底层和原理,但是 sql 写得多了,也就会发现这样的规律,比如说别名的运用。

如下,给表 emp 取个别名 a,分别在 select 子句、where 子句、group by 子句中引用,都能正确执行。说明 from 子句的执行在这三个子句之前。

0482fdccb3c9b0377bd0b513a7f9ded1.png

再如下:在 select 子句中给 count(1) 起了个别名为 num,在 order by 子句中引用这个别名,执行正确。在 where 子句中引用这个别名,则执行错误。说明这三个子句的执行顺序为 where > select > order by

9d418b16f61f964e16e840e9c1d20bd1.png

有兴趣的朋友可以想办法验证一下其他步骤。

34deedc4fdef28f2aa49b3b0926ccaf1.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值