kkevin_zzhang 2021-12-30 18:01 采纳率: 50%
浏览 19
已结题

Oracle数据连续时取连续值的第一个

数据表格式:

id                    year    month
110108196802226415    2020    1    
110108196802226415    2020    2    
110108196802226415    2020    3    
110108196802226415    2020    4    
110108196802226415    2020    5    
110108196802226415    2020    7    
110108196802226415    2020    8    
110108196802226415    2020    9    
110108196802226415    2020    10    
110108196802226415    2020    11

想要在oracle中取得下面数据格式,月份连续时取连续值的第一个

结果集            
id                    year    month beginMonth
110108196802226415    2020    1    1
110108196802226415    2020    2    1
110108196802226415    2020    3    1
110108196802226415    2020    4    1
110108196802226415    2020    5    1
110108196802226415    2020    7    7
110108196802226415    2020    8    7
110108196802226415    2020    9    7
110108196802226415    2020    10    7
110108196802226415    2020    11    7
  • 写回答

2条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2021-12-30 20:52
    关注

    这题有意思,我本来打算用开窗函数来做,但是想想用迭代思路更清晰,就凑了个迭代的sql出来,数据结果是对的,但应该还可以优化

    with cte(year,
    month,
    l,
    begin_month,
    b) as
     (select year, month, month + 1 l, month begin_month, month b
        from month_test
       where year = 2020
         and month = 1
      union all
      select cte.year,
             cte.l,
             cte.l + 1,
             case
               when b.month is null then
                cte.l + 1
               else
                cte.begin_month
             end,
             b.month
        from cte, month_test b
       where cte.l = b.month(+)
         and cte.l <= 12)
    select YEAR, MONTH, begin_month from cte where b is not null
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 5月25日
  • 已采纳回答 5月17日
  • 创建了问题 12月30日

悬赏问题

  • ¥30 Matlab打开默认名称带有/的光谱数据
  • ¥50 easyExcel模板 动态单元格合并列
  • ¥15 res.rows如何取值使用
  • ¥15 在odoo17开发环境中,怎么实现库存管理系统,或独立模块设计与AGV小车对接?开发方面应如何设计和开发?请详细解释MES或WMS在与AGV小车对接时需完成的设计和开发
  • ¥15 CSP算法实现EEG特征提取,哪一步错了?
  • ¥15 游戏盾如何溯源服务器真实ip?需要30个字。后面的字是凑数的
  • ¥15 vue3前端取消收藏的不会引用collectId
  • ¥15 delphi7 HMAC_SHA256方式加密
  • ¥15 关于#qt#的问题:我想实现qcustomplot完成坐标轴
  • ¥15 下列c语言代码为何输出了多余的空格