oracle数据库中多列分组查询,oracle数据库学习相关笔记-分组查询

-- 分组查询学习

--关键字:group by 分组字段名,分组字段名,....

--注意一:使用了分组后,在select语句中只能出现分组字段和多行函数

--注意二:如果使用了多字段分组,则先按照第一字段分组,然后每个小组继续按照第二个字段继续分组...

--注意三:在where子句中不允许出现多行函数

--分组筛选

--关键字:having

--作用:针对分组进行分组后的数据筛选,允许使用多行函数

--注意:having关键必须和分组结合使用,不允许单独使用

--where和having的比较:

--where 后不允许使用多行函数,having允许出现多行函数

--where字句和having都可以使用普通字段直接进行筛选,但是where的效率高于having

-- where执行顺序:from--->where--->group by--->select--->order by

-- having执行顺序:from--->group by-->select--->having--->order by

-- 结论:在分组语句中,使用where进行字段级别的筛选,使用having进行多行函数的筛选。

--问题引入:

--查询最高工资和员工数

select max(sal),count(*) from emp;

-- 查询不同部门的最高工资

select deptno, max(sal) from emp group by deptno;

-- 查询不同工作岗位的员工数

select job, count(*) from emp group by job

-- 查询不同部门的不同工作岗位的人数

select deptno,job,count(*) from emp group by deptno,job

-- 查询不同部门的不同工作岗位的并且人数大于1的信息

select deptno,job,count(*) from emp group by deptno,job having count(*)>1

-- 查询部门号大于10的不同部门的不同工作岗位的人数

select deptno,job,count(*) from emp group by deptno,job having deptno>10

select deptno,job,count(*) from emp where deptno>10 group by deptno,job--效率更高

-- 查询部门号大于10不同部门的不同工作岗位的并且人数大于1的信息

select deptno,job,count(*) from emp group by deptno,job having deptno>10 and count(*)>1

select deptno,job,count(*) from emp where deptno>10 group by deptno,job having count(*)>1 --效率更高