温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

oracle如何根据字段分组排序取其第一条数据

发布时间:2023-02-28 10:10:16 来源:亿速云 阅读:114 作者:iii 栏目:开发技术

这篇文章主要介绍“oracle如何根据字段分组排序取其第一条数据”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“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

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

    关于“oracle如何根据字段分组排序取其第一条数据”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI