Oracle中的having()函数
阅读原文时间:2023年09月27日阅读:1

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