-- 分组查询学习
--关键字: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