当前位置:   article > 正文

数据分析场景,连号相关业务

数据分析场景,连号相关业务

连号相关业务

业务场景:现在需要从a列一堆编号中,将连号范围在10以内的数据分别分成一组。

在这里插入图片描述
先看实先效果
在这里插入图片描述
演示的为db2数据库,需要含有窗口函数,或者可以获取到当前数据偏移的上一位数据

  1. 第一步:将A列数据正序
  2. 第二步:获取每一行的向上偏移的那一个数据,并开一个新的列,例如1、9、11 ;那么开一列就是1:1、9:1、11:9
  3. 第三步:判断相邻连个数的差值是否小于10,如果小于标记为0,否则就是1,开一个新列B
  4. 第四步:根据每一行的编号数据从上往下的,条件是小于等于当前编号求和开出C列。这时C列如果数据一样表明连号,如果出现一次表明不连号
  5. 第五步,根据分组后的数据group by然后汇总,记得加一个条件,分组个数要大于1,证明是多个连号
    6.效果、代码如下:
    在这里插入图片描述
WITH nums(num_no) AS (
VALUES 1,11,19,29,39,47,57,66,74,83,92,101,110,119,129,137,145,154
),result1 as(
SELECT 
num_no,
nvl(lag(num_no, 1) OVER (ORDER BY num_no),num_no) AS next_num_no
FROM nums
),result2 as (
select
num_no,
-- 如果相减小于10标记0 ,想法大于等于10或者等于0就标记1
(case
when (num_no - next_num_no) >= 10
or (num_no - next_num_no) = 0 then 1
else 0
end) as B
from result1
),result4 as (
select *,(select sum(B) from result2 where num_no<=t1.num_no) as C
from result2 t1
)
select C, LISTAGG(num_no,';'),count(C) from result4
group by C
having count(C)>1



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/499645
推荐阅读
相关标签
  

闽ICP备14008679号