这篇文章主要介绍了oracle实现根据字段分组排序,取其第一条数据方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
以某个字段分组 取其第一条数据
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 别名
)
oracle中对表中数据分组排序取最值
首先创建操作表emp
业务场景
需要查询相同部门的员工,按照入职日期排序,并且取出每个部门最新入职的员工信息!
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实现根据字段分组排序,取其第一条数据


基础教程推荐
猜你喜欢
- SQL Server如何设置用户只能访问特定数据库和访问特定表或视图 2023-07-29
- oracle19c卸载教程的超详细教程 2023-07-23
- oracle数据库排序后如何获取第一条数据 2023-07-24
- Mariadb数据库主从复制同步配置过程实例 2023-07-25
- redis 数据库 2023-09-13
- redis乐观锁与悲观锁的实战 2023-07-13
- Windows10系统中Oracle完全卸载正确步骤 2023-07-24
- Python安装第三方库的方法(pip/conda、easy_install、setup.py) 2023-07-28
- Python常见库matplotlib学习笔记之画图中各个模块的含义及修改方法 2023-07-27
- Java程序员从笨鸟到菜鸟(五十三) 分布式之 Redis 2023-09-11