oracle实现根据字段分组排序,取其第一条数据

2023-12-04 0 486
目录
  • 以某个字段分组 取其第一条数据
  • 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 别名

    oracle中对表中数据分组排序取最值

    首先创建操作表emp

    oracle实现根据字段分组排序,取其第一条数据

    业务场景

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

    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实现根据字段分组排序,取其第一条数据

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持悠久资源。

    收藏 (0) 打赏

    感谢您的支持,我会继续努力的!

    打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
    点赞 (0)

    悠久资源 Oracle oracle实现根据字段分组排序,取其第一条数据 https://www.u-9.cn/database/oracle/67345.html

    常见问题

    相关文章

    发表评论
    暂无评论
    官方客服团队

    为您解决烦忧 - 24小时在线 专业服务