SQL ASNI where from group order 顺序 where和having,SQL底层执行原理

在这里插入图片描述
SQL语句执行顺序:
from–>where–>group by -->having — >select --> order

第一步:from语句,选择要操作的表。

第二步:where语句,在from后的表中设置筛选条件,筛选出符合条件的记录。

第三步:group by语句,把筛选出的记录进行分组。

第四步:having语句,设置条件筛选分组后的数据。

第五步:select语句,选取经过上述流程后的结果集。

第六步:order by语句:将select后的结果集按照顺序展示出来。

注意:

掌握SQL语句执行流程非常重要,是理解并写好SQL语句的前提,根据实际业务逻辑要执行的数据库操作对应到SQL语句的执行流程能够帮助我们快速写出相应功能的标准SQL语句。

where和having区别:
where在group by前, having在group by 之后。
where 用于 过滤数据行 , having 用去过滤分组,是结果集过滤
where 针对数据库文件进行过滤,having 针对查询结果进行过滤,也就是说 where 根据数据表中的字段直接进行过滤的 having是根据前面已经查询出的字段(结果集)进行过滤 ,where 先过滤 having 后过滤
where中不能使用聚合函数,having中可以使用聚合函数。原因:因为聚合函数是针对结果集进行的,但where是在查询结果集之前进行,故where中不能使用聚合函数;having是针对结果集做筛选的,故一般把聚合函数放在having中。
HAVING 关键字和 WHERE 关键字都可以用来过滤数据,且 HAVING 支持 WHERE 关键字中所有的操作符和语法。

SQL ASNI where from group order 顺序 where和having,SQL底层执行原理_第1张图片

sql 查询执行顺序

SQL 92

select col1,col2,avg(col3)...coln      ###  avg  聚合函数又叫组函数,

from  t1,t2.。。tn

where 多表查询的连接条件   and   不包含聚合函数的过滤条件

group by   col3.。。

having   包含聚合函数的过滤条件     # sum(xxx)>1000

order by    coln  asc  ,coln  desc
limit          #   sql server  中没有limit 关键字

SQL 99

select col1,col2,avg(col3)...coln      ###  avg  聚合函数又叫组函数,

from  t1  [leftrightinner] join t2  on 多表查询的连接条件

where  不包含聚合函数的过滤条件

group by   col3.。。

having   包含聚合函数的过滤条件     # sum(xxx)>1000

order by    coln  asc  ,coln  desc
limit          #   sql server  中没有limit 关键字

SQL ASNI where from group order 顺序 where和having,SQL底层执行原理_第2张图片

在select 语句执行这些【from ——>where——>group by——>having——> select ——>order by——>limit】步骤时,每步都会产生一个虚拟表,然后这个虚拟表传入一下步中作为输入。 这些步骤隐含在sql执行过程中,对于我们来说是不可见的。。

子查询

在select 语句中,除了 group by和 limit 之前,其他的位置都可以声明 子查询

你可能感兴趣的:(sql,数据库,oracle)