首页 > 数据库 >oracle partition by与group by 的区别

oracle partition by与group by 的区别

时间:2022-11-08 18:05:11浏览次数:34  
标签:02 salary 01 group 03 partition dept oracle 1000


SELECT   b,   c,   d,SUM(d)   OVER(PARTITION   BY   b,c   ORDER   BY   d)   e   FROM   a

  


今天看到一个老兄的问题,
大概如下:
查询出部门的最低工资的userid 号
表结构:




D号      工资      部门 
userid salary dept
1 2000 1
2 1000 1
3 500 2
4 1000 2




 

有一个高人给出了一种答案:

SELECT MIN (salary) OVER (PARTITION BY dept ) salary, dept    
FROM ss




运行后得到:

1000 1 
1000 1
500 2
500 2




楼主那位老兄一看觉得很高深。大叹真是高人阿~
我也觉得这位老兄实在是高啊。

但我仔细研究一下发现那位老兄对PARTITION BY的用法理解并不深刻。并没有解决楼主的问题。
大家请看我修改后的语句

SELECT userid,salary,dept,MIN (salary) OVER (PARTITION BY dept ) salary   
FROM ss




运行后的结果:

userid   salary dept      MIN (salary) OVER (PARTITION BY dept ) 
1 2000 1 1000
2 1000 1 1000
3 500 2 500
4 1000 2 500




大家看出端倪了吧。
高深的未必适合。

一下是我给出的答案:

SELECT * FROM SS 
INNER JOIN (SELECT MIN(SALARY) AS SALARY, DEPT FROM SS GROUP BY DEPT) SS2
USING(SALARY,DEPT)




运行后的结果:

salary dept     userid 
1000 1 2
500 2 3




由此我想到总结一下group by和partition by的用法
group by是对检索结果的保留行进行单纯分组,一般总爱和聚合函数一块用例如AVG(),COUNT(),max(),main()等一块用。

partition by虽然也具有分组功能,但同时也具有其他的功能。
它属于oracle的分析用函数。
借用一个勤快人的数据说明一下:

sum()   over   (PARTITION   BY   ...)   是一个分析函数。   他执行的效果跟普通的sum   ...group   by   ...不一样,它计算组中表达式的累积和,而不是简单的和。  
   
表a,内容如下:  

B C D   
02 02 1
02 03 2
02 04 3
02 05 4
02 01 5
02 06 6
02 07 7
02 03 5
02 02 12
02 01 2
02 01 23
select   b,c,sum(d)   e   from   a   group   by   b,c




 



得到:  

B C E   
02 01 30
02 02 13
02 03 7
02 04 3
02 05 4
02 06 6
02 07 7




而使用分析函数得到的结果是:  

SELECT   b,   c,   d,   SUM(d)   OVER(PARTITION   BY   b,c   ORDER   BY   d)   e   FROM   a





B C E   
02 01 2
02 01 7
02 01 30
02 02 1
02 02 13
02 03 2
02 03 7
02 04 3
02 05 4
02 06 6
02 07 7




结果不一样,这样看还不是很清楚,我们把d的内容也显示出来就更清楚了:   

B C D E   
02 01 2 2 d=2,sum(d)=2
02 01 5 7 d=5,sum(d)=7
02 01 23 30 d=23,sum(d)=30
02 02 1 1 c值不同,重新累计
02 02 12 13
02 03 2 2
02 03 5 7
02 04 3 3
02 05 4 4
02 06 6 6
02 07 7 7



标签:02,salary,01,group,03,partition,dept,oracle,1000
From: https://blog.51cto.com/u_15785444/5833975

相关文章

  • oracle批处理开启或者关闭服务
    机子上装着Oracle,但并不是很常要用到,所以把原先自启动的服务设成手动,这样便不会每天开机很慢,也不会占用系统资源。​​​​我写了两个bat文件(批处理)。启动Oracle.bat@echo......
  • oracle case when 用法总结
    ​​Oracledbms_jobpackage用法小结​​ORACLECASEWHEN及SELECTCASEWHEN的用法  Case具有两种格式。简单Case函数和Case搜索函数。--简单case函数casesex......
  • oracle添加字符串连接聚合函数wm_concat
    自从oracle新版废弃了wm_concat函数后,各种不方便,网上搜索到的自定义聚合函数也是问题多多,例如用varchar2(32767)定义返回值类型,4000会超,32767不一样会超吗?所以最终用clob类......
  • mybatis中oracle的merge语句示例
    mergeinto在mybatismapper.xml中的用法示例<updateid="mergeTask"parameterType="java.util.List">MERGEINTODM_TASKaUSING(<forea......
  • Oracle、MySQL等数据库故障处理优质文章分享 | 10月汇总
    墨天轮社区于9月起持续举办【聊聊故障处理那些事儿】DBA专题征文活动,每月进行评优发奖,鼓励大家记录工作中遇到的数据库故障处理过程,不仅用于自我复盘与分析,同时也能帮助其......
  • iOS15.6以后UITableview设置UITableViewStyleGrouped底部会多出一段空白
    在适配iPhone14的过程中,发现之前没问题的UITableview底部会多出一截,查看低版本系统手机正常显示,iOS15.6的iPhone11也有同样的问题。继iOS11以后UITableview多出空白又有新......
  • API Groups
    在kubernetes中,除了可以使用kubectl工具来操作集群外,还可以直接使用API来操作集群。如:通过API查看kubernetes版本信息:访问POD:kubernetesAPIResourcesspacekube-ap......
  • Oracle ASM Filter Driver
       OracleASMFilterDriver(asmfd)是oracle12c gi开始提供的一个内核模块位于oracleasmdiskio请求路径之中,asmfd屏蔽任何非oracle产生的io写请求,降低了o......
  • MybatisPlus Lambda表达式 聚合查询 分组查询 COUNT SUM AVG MIN MAX GroupBy
    一、序言众所周知,MybatisPlus在处理单表DAO操作时非常的方便。在处理多表连接连接查询也有优雅的解决方案。今天分享MybatisPlus基于Lambda表达式优雅实现聚合分组查询。......
  • 事件10841解决oracle 9i中JDBC Thin Driver ORA-00600 [ttcgcshnd-1]的异常
    文档课题:事件10841解决oracle9i中JDBCThinDriverORA-00600ttcgcshnd-1的异常.用thindriver连接Oracle9i时,出现exception,如下所示java.sql.SQLException:ORA-00600:......