oracle实现根据字段分组排序,取其第一条数据(oracle分组排序后取第一条记录)干货满满

随心笔谈4个月前更新 admin
201 00
🌐 经济型:买域名、轻量云服务器、用途:游戏 网站等 《腾讯云》特点:特价机便宜 适合初学者用 点我优惠购买
🚀 拓展型:买域名、轻量云服务器、用途:游戏 网站等 《阿里云》特点:中档服务器便宜 域名备案事多 点我优惠购买
🛡️ 稳定型:买域名、轻量云服务器、用途:游戏 网站等 《西部数码》 特点:比上两家略贵但是稳定性超好事也少 点我优惠购买

文章摘要

这篇文章主要介绍了如何在Oracle数据库中通过分组排序并提取最值。文章详细解释了如何利用窗口函数`rank()`和`row_number()`来实现以下功能: 1. **分组排序并取最值** 使用`rank()`函数对数据进行分组排序后,提取每组中的第一条数据,用于获取每个部门中入职日期最早的员工信息。例如: ```sql select t1.*, rank() over(partition by t1.deptno order by t1.hiredate desc) as rankNo from emp t1 where rankNo = 1; ``` 2. **窗口函数的应用** 通过`row_number()`函数同样可以实现相同的效果。语法如下: ```sql select t1.*, row_number() over(partition by t1.deptno order by t1.hiredate desc) as row_number from emp t1 where row_number = 1; ``` 文章还提到,窗口函数通过`partition by`实现分组,`order by`实现排序,从而在每组中取第一条数据。这种方法简单高效,适用于需要快速提取组内最值的场景。



目录以某个字段分组 取其第一条数据oracle中对表中数据分组排序取最值首先创建操作表emp业务场景总结
select *
? from (select t.app_id,
? ? ? ? ? ? ? ?t.emp_no,
? ? ? ? ? ? ? ?t.device_id,
? ? ? ? ? ? ? ?t.device_type,
? ? ? ? ? ? ? ?t.last_connect_time,
? ? ? ? ? ? ? ?t.device_model,
? ? ? ? ? ? ? ?rank() over(partition by t.device_type order by t.last_connect_time desc) rankNo
? ? ? ? ? from table_name t) e
?where e.rankNo=1;

解释下,上面sql的意思:

rank() over(partition by e.commandid order by e.systemid desc) rankNo (
partition by 根据什么进行分组,
order by 根据什么进行排序,
rank() over() 进行排名
rankNo 别名

需要查询相同部门的员工,按照入职日期排序,并且取出每个部门最新入职的员工信息!

select * from (select t1.*,row_number() over(partition by t1.deptno order by hiredate desc) as row_number from emp t1) where row_number=1

首先会根据各个部门里面的人员按照入职时间(hiredate)排序,然后取出每个部门排序第一的员工。

效果如下:

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:Oracle分组函数之ROLLUP的基本用法Oracle数据库按时间进行分组统计数据的方法Oracle 中文字段进行排序的sql语句

© 版权声明

相关文章