----分组查询及筛选学习:
---关键字:group by 分组字段名,分组字段名.......
-----注意1:使用了分组后,在select语句中只允许出现分组字段和多行函数。
-----注意2:如果是多字段分组,则先按照第一字段分组,然后每个小组继续按照第二个字段分组,以此类推。
-----注意3:在when子句中不允许出现多行函数。
---分组筛选
-----关键字:having
----作用:针对分组进行分组后的数据筛选,允许使用多行函数。
----注意:having关键字必须与分组结合使用,不允许单独使用。
----where和having的比较
---when子句中不允许出现多行函数,having中允许出现多行函数.
---where字句和having都可以使用普通字段直接进行筛选,但是where的效率高于having
---where执行顺序:from--->where--->group by--->select--->order by
---having的执行顺序:from--->group by--->select--->having--->order by
--------结论:在分组语句中,使用where进行字段级别的筛选,使用having进行多行函数的筛选
例子:
(1)查询最高工资和员工数
select max(sal),count(*) from enp;
(2)查询不同部门的最高工资
select deptno,max(sal) from emp grow by deptno;
(3)查询不同工作的个数
select count(direct(job)) from emp;
(4)查询不同工作岗位的员工数
select job,count(*) from emp group by job;
(5)查询不同部门的不同工作岗位的员工数
select deptno,lower(job),count(*) from emp group by deptno,job order by deptno
(6)查询不同部门的不同工作岗位的并且人数大于1的信息
select deptno,lower(job),count(*) from emp group by deptno,job having count(*)>1 order by deptno;
(7)查询部门号大于10的的不同部门,不同工作岗位的人数
select deptno,lower(job),count(*) from emp group by deptno,job having deptno>10 order by deptno;