Oracle数据库之分组查询及排序
分组查询:使用 group by 来设置分组,把该列具有相同值的多条记录当成一组记录来处理,然后只会输出一条记录,得到的结果会默认使用升序的方式进行排列。
规则:
(1)如果使用了分组函数,或者是 group by 语句,当他出现在 select 列表中的字段,要么出现在组合函数中,要么出现在 group by 子句中,否则会报错。
(2)group by 子句的字段可以不用出现在 select 列表中。
(3)使用组函数可以不使用 group by 子句,此时所有的查询结果作为一组。
-- 首先,查看emp 表中的所有数据。
select * from scott.emp;
-- 在员工表中,按照部门来分组。
select deptno from scott.emp group by deptno;
-- 在员工表中,查询每个部门的编号,员工数,总工资,平均奖金
select deptno, count(*), sum(sal), avg(sal)
from scott.emp group by deptno;
-- 在分组的时候,有时候需要进行进一步的过滤,可以使用 having 子句
-- having 是指“拥有xxx”的意思,也就是跟着一个条件,可以进行过滤筛选。
select deptno, count(*), sum(sal), avg(sal)
from scott.emp
group by deptno;
select deptno, count(*), sum(sal), avg(sal)
from scott.emp
group by deptno
having sum(sal) > 9000;
-- having 和 where 区别:
-- 1. 都是作为条件过滤。
-- 2. where 是在分组之前使用的,having 是在分组之后使用的,参照物是 group by
-- 3. where 子句中不能使用组函数(聚合函数),但 having 可以
升序排序:order by ...ASC(放在最后,对结果集进行排序)
降序排序:order by ...DESC(放在最后,对结果集进行排序)
-- 关键字的使用顺序
select、from、where、group by、having、order by