select查询中where、group by和having的作用时间介绍

本文详细介绍了SQL查询中where、group by和having子句的使用和执行顺序。通过实例展示了它们如何筛选数据、进行分组统计以及在聚合结果上进行过滤。where子句用于初步筛选数据,group by对筛选结果进行分组,having则在分组后对结果进行进一步筛选。

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

select查询中可以同时出现wheregroup byhaving子句,本文通过一个例子进行介绍它们之间的区别和作用时间。

 

Book表中的数据如下:

Book表执行如下查询:

select 类别, AVG(定价) from Book

### 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查询从左到右、自上而下的书写方式与实际内部执行路径之间的差异。掌握这一点有助于优化性能并写出更高效的查询语句
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值