oracle分组函数
admin
2023-05-08 23:01:59
0

分组函数:作用于一组值,并对一组数据返回一个值;

分组函数的使用:

常用的分组函数:

Avg(求平均值),sum(求总和),min(求最小值),max(求最大值),count(求总个数),wm_concat(行转列)

select count( distinct deptno) from emp ;

行转列: select deptno 部门号,wm_concat(ename) 部门中员工的名字  from emp group by deptno;

----------------------------------------------------

分组函数与空值:(分组函数会自动忽略空值)

1.      统计员工的平均工资

Select sum(sal)/count(*) 一,sum(sal)/count(sal) 二,avg(sal) from emp;

 

2.      统计员工的平均奖金

Select sum(comm)/count(*),  sum(comm)/count(comm) 二,avg(comm) from emp;

 

注意:nvl函数使分组函数无法忽略空值

Selectsum(comm)/count(*),   sum(comm)/count(nvl(comm,0)) from emp;

Comm为空时,nvl函数返回0,0不为null,所以count不会忽略

------------------------------------------------------

Group by子句的使用

1.求部门号和部门的平均工资

Selectdeptno,avg(sal) from emp

Group bydeptno;

 抽象:

Selecta,b,c,avg(x) from table

Group bya,b,c;

规定:select列表中所有未包含在组函数中的列都应该包含在group by 子句中;

相反的,在group by 中的列,不必包含在组函数中

 

多个列的分组:(分组逻辑:先按照group by 后面第一个列分组,如果第一个列相同,再按照第二个列分组,如果所有的列都相同,那么这就是同一组中的数据)

按照部门,不同的职位,统计员工工资的总额

Select deptno,job ,sum(sal) from emp

Group by deptno,job;



-------------------------------------------------------

Having子句的使用:(过滤分组后的数据)

平均工资大于2000的部门

Select deptno,avg(sal)

From emp

Having  avg(sql)>2000;

 

Wherehaving的区别:

where子句后面不能使用分组函数

 

Wherehaving可以通用的情况(没有分组函数的情况下可以通用,但是从

Sql优化的角度上考虑,尽量使用where)

查询10号部门的平均工资

1.      Where

Select deptno,avg(sal) from emp wheredeptno=10 group by deptno

 

2.      Having

Select deptno,avg(sal) from empgroup by deptno having deptno=10

-----------------------------------------------------------------------------

在分组函数中使用orderby 排序(默认是asc升序)

1.Select deptno ,avg(sal)

From emp

Group by deptno

Order by avg(sal)

2.

Select deptno ,avg(sal)

From emp

Group by deptno

Order by 2—这里的2代表select语句后面的第二列,这里即avg(sal)

----------------------------------------------------------------------------

分组函数的嵌套

Select  max(avg(sal))

From emp

Group by deptno;

-----------------------------------------------------------------------

Group by 语句的增强:

(1)Selext deptno,job,sum(sal)

From emp

Group by deptno,job

 

(2)Select deptno,sum(sal)

From emp

Having deptno

 

(3)Select sum(sal) from emp

 等价于(1+2+3

Select deptno,job,sum(sal) from emp group byrollup(deptno,job);

语法:

Group by rollup(a,b)

等价于:groupby a,b+group by  a+group by null

 

Break on deptno skip 2;--相同的部门号只显示一次,不同的部门号之间

跳过两行

--详细的可以看看sql-plus的报表功能

相关内容

热门资讯

河南一地入选!国家级试点城市名... 【大河财立方消息】5月14日消息,工业和信息化部、财政部公示第三批制造业新型技术改造城市试点拟入选名...
周日有大到暴雨!郑州将有连续性... 受切变线和低空急流共同影响,16日至18日我市将有一次明显降水过程。15日夜里有阵雨,16日下午到夜...
降的是费率 增的是底气 河南失... 中国铁路郑州局集团有限公司开展业务技能实操训练。受访者供图一笔失业保险稳岗返还资金,到了企业手里,可...
宇树科技发布全球首款载人变形机... 宇树科技CEO王兴兴与载人变形机甲GD01击拳。宇树科技供图5月12日,宇树科技发布全球首款量产版载...
洗衣机地漏盖不闭合怎么修 如果您发现您的洗衣机地漏盖不闭合,这可能是由于以下原因之一: 1. 漏水管生锈或破裂:这可能是漏水...
坚定不移沿着习近平总书记指引的... 5月12日,安阳市林州市红旗渠青年洞景区研学热潮涌动,来自各地的学生沿渠岸栈道有序前行,近距离触摸“...
波轮洗衣机不盖盖儿是不是不工作 一定不会工作,因为洗衣机盖子上有自动刹车装置。如果洗衣机盖子没盖上,就无法工作。洗衣机不工作还有其他...
美亚科技被出具警示函!此前A股... 【大河财立方消息】5月13日,广东证监局披露行政监管措施决定书,对广东美亚旅游科技集团及相关责任人出...
凤凰直击:中美元首会晤,媒体争... 5月14日上午,中美元首举行会谈。凤凰卫视记者霍伟伟在人民大会堂发回现场报道。
如何修复洗衣机后盖盖不上 洗衣机后盖无法盖上是相当常见的问题。如果发现洗衣机后盖无法盖上,建议首先仔细检查后盖和机器是否与之前...