oracle实现根据字段分组排序,取其第一条数据
更新时间:2023年02月28日 08:41:39 作者:superjr1
这篇文章主要介绍了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使用fy_recover_data恢复truncate删除的数据
这篇文章主要介绍了Oracle使用fy_recover_data恢复truncate删除的数据,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下2022-07-07
Windows Server 2012 安装oracle11g(图文教程)
这篇文章主要介绍了Windows Server 2012 安装oracle11g(图文教程),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-12-12
win平台oracle rman备份和删除dg备库归档日志脚本
本文介绍win平台oracle rman备份和删除dg备库归档日志脚本2013-11-11


最新评论