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 @   HANDHEAD  阅读(23143)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示