Oracle中的having()函数

having函数用在group by子句的后面,对分组结果集进行条件筛选。
1、having子句包含聚合函数
/*列出平均工资在1000之上,并且最低工资不低于800的工作信息*/
select
job,avg(sal),min(sal) from emp
group by job
having avg(sal)>1000 and min(sal)>=800--avg(),min()为聚合函数
2、where子句用在分组之前筛选数据;having子句分组之后使用,对分组结果集进一步筛选
/*列出不是销售员最低薪资大于1500的各种工作的信息*/
select job,min(sal) from emp
where job<>'SALESMAN'
group by job
having min(sal)>1500

3、having子句可以使用别名

/*显示非销售人员工作名称以及从事同一工作雇员的月工资的总和,并且要满足从事同一工作的雇员的月工资合计大于$5000,输出结果按月工资的合计升序排列*/
SELECT
job,SUM(sal) S_U_M FROM emp WHERE job<>'SALESMAN' GROUP BY job
HAVING S_U_M>5000--S_U_M为SUM(sal)的别名 ORDER BY S_U_M

 

posted @ 2019-05-24 17:30  HANDHEAD  阅读(22920)  评论(0编辑  收藏  举报