sql中语句的执行顺序

Posted 香风智乃哈~

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql中语句的执行顺序相关的知识,希望对你有一定的参考价值。

一个sql的大致语句如下:

select ... 
from ...
where ...
group by ...
having ...
order by ...

这些语句存在着执行顺序,规则如下:

先执行from ,查找到在哪个表中进行查询
再执行where,判断条件
再执行group by 进行分组操作
执行分组函数,按照group by里面的分组条件
执行having,进行条件判断
执行select语句
最后执行order by 将数据进行排序

从这个排序规则可以看出分组函数只能出现在having、select、order by的后面,出现在其他地方都是错误的。
并且,如果select和having后面出现了分组函数,那么select和having后面没有被分组函数修饰的列,就必须出现在group by后面(也就是作为分组的条件,这样才不会报错)

以上是关于sql中语句的执行顺序的主要内容,如果未能解决你的问题,请参考以下文章

Hive SQL语句执行顺序

SQL语句执行顺序

sql语句执行顺序

[zz]sql语句执行顺序

SQL语句执行流程与顺序原理解析

SQL执行顺序