广告合作
  • 今日头条

    今日头条

  • 百度一下

    百度一下,你就知道

  • 新浪网

    新浪网 - 提供新闻线索,重大新闻爆料

  • 搜狐

    搜狐

  • 豆瓣

    豆瓣

  • 百度贴吧

    百度贴吧——全球领先的中文社区

  • 首页 尚未审核订阅工具 订阅

    工作小技巧--Oracle之row_number() over() 使用

    来源:网络收集  点击:  时间:2024-07-29
    【导读】:
    Oracle数据库提供了很多好玩有意思的函数给我们用,比如今天要说的 row_number() over(partition by 列名1 order by 列名2 ) 这个函数,其操作的是我们的查询结果集,对结果集按照列名1进行分组,然后在组内按照列名2进行排序,最后为结果集中每一条记录返回一个序号(每组的序号都是从1开始)。工具/原料more一台安装了Oracle数据库的电脑方法/步骤1/4分步阅读

    业务需求场景描述:

    我们有一张业务表,其中每条记录代表一辆车在某一天某一个特定小时的经纬度信息,我们需要从中抽取每一辆车在每一天最后上报的经纬度信息(此处需要注意的是各车辆在某天最后上报经纬度的小时并不相同)。

    图1示:我们的业务表建表语句

    图2示:我们的业务表数据展示

    图3示:我们最后期望得到的数据展示

    2/4

    根据需求,我们先在查询结果中对每一辆车每一天上报的多条数据进行编号,这个编号数据就需要使用 row_number() over() 函数来获取:我们根据车牌号、年、月、日对结果集进行分组,并按照小时进行倒序排序。

    SQL语句为:

    select carposinfo.*, row_number() over(partition by carno,cyear, cmonth, cday order by chour desc) as seq from carposinfo

    3/4

    有了上面获取的数据,我们就可以根据编号进行过滤,我们只需获取所有编号=1的行数据即可,这里需要使用一个子查询,SQL语句为:

    select carno, cyear, cmonth, cday, clon, clat from (

    -- 子查询,即上面我们获取数据进行编号的查询语句

    select carposinfo.*, row_number() over(partition by carno, cyear, cmonth, cday order by chour desc) as seq from carposinfo )where seq = 1 order by carno, cyear, cmonth, cday

    4/4

    总结:通过 Oracle 为我们提供的这个函数 row_number() over() 我们可以对查询结果集添加一列编号数据,并通过这列编号对结果集再次进行过滤或其他业务处理。

    ROW_NUMBER
    本文关键词:

    版权声明:

    1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。

    2、本站仅提供信息发布平台,不承担相关法律责任。

    3、若侵犯您的版权或隐私,请联系本站管理员删除。

    4、文章链接:http://www.1haoku.cn/art_1033181.html

    相关资讯

    ©2019-2020 http://www.1haoku.cn/ 国ICP备20009186号05-06 15:33:37  耗时:0.027
    0.0273s