Group By 和 Having, Where ,Order by语句的执行顺序(转载)

SQL查询流程解析

一个SQL语句往往会产生多个临时视图,那么这些关键字的执行顺序就非常重要了,因为你必须了解这个关键字是在对应视图形成前的字段进行操作还是对形成的临时视图进行操作,这个问题在使用了别名的视图尤其重要。

以上列举的关键字是按照如下顺序进行执行的:Where, Group By, Having, Order by。

首先where将最原始记录中不满足条件的记录删除(所以应该在where语句中尽量的将不符合条件的记录筛选掉,这样可以减少分组的次数),然后通过Group By关键字后面指定的分组条件将筛选得到的视图进行分组,接着系统根据Having关键字后面指定的筛选条件,将分组视图后不满足条件的记录筛选掉,然后按照Order By语句对视图进行排序,这样最终的结果就产生了。

在这四个关键字中,只有在Order By语句中才可以使用最终视图的列名

### Oracle SQL 查询执行顺序 在构建复杂的SQL查询时,理解各子句的处理顺序至关重要。按照标准ANSI SQL语法,在Oracle数据库中的查询语句会遵循特定的解析流程: - **FROM**: 首先指定数据源表或视图[^2]。 ```sql SELECT * FROM employees; ``` - **WHERE**: 接着应用条件表达式筛选满足要求的数据行,减少后续操作所需处理的数据量[^1]。 ```sql SELECT first_name, last_name FROM employees WHERE department_id = 50; ``` - **GROUP BY**: 对经过`WHERE`过滤后的结果集按一个或多列进行分组,以便能够对每组计算聚合函数的结果[^3]。 ```sql SELECT department_id, COUNT(*) FROM employees WHERE salary > 6000 GROUP BY department_id; ``` - **HAVING**: 进一步限制由`GROUP BY`产生的汇总信息,只保留符合条件的那些分组。 ```sql SELECT department_id, AVG(salary) as avg_salary FROM employees GROUP BY department_id HAVING AVG(salary) > 8000; ``` - **SELECT**: 此阶段决定最终要返回哪些字段以及如何显示这些字段(比如重命名列名)。值得注意的是,尽管在这个位置编写`SELECT`关键字,但实际上它是在所有其他逻辑处理之后才被执行。 ```sql SELECT d.department_name, e.avg_salary FROM departments d JOIN ( SELECT department_id, AVG(salary) as avg_salary FROM employees GROUP BY department_id HAVING AVG(salary) > 8000 ) e ON d.department_id = e.department_id; ``` - **ORDER BY**: 最后根据一列或多列对结果集排序,可以升序(ASC,默认行为) 或降序(Desc)。 ```sql SELECT employee_id, first_name, last_name, hire_date FROM employees WHERE job_id = 'IT_PROG' ORDER BY hire_date DESC; ``` 上述描述展示了典型的SQL查询从左到右、自上而下的书写方式与实际内部执行路径之间的差异。掌握这一点有助于优化性能并写出更高效的查询语句
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值