连号相关业务
业务场景:现在需要从a列一堆编号中,将连号范围在10以内的数据分别分成一组。
先看实先效果
演示的为db2数据库,需要含有窗口函数,或者可以获取到当前数据偏移的上一位数据
- 第一步:将A列数据正序
- 第二步:获取每一行的向上偏移的那一个数据,并开一个新的列,例如1、9、11 ;那么开一列就是1:1、9:1、11:9
- 第三步:判断相邻连个数的差值是否小于10,如果小于标记为0,否则就是1,开一个新列B
- 第四步:根据每一行的编号数据从上往下的,条件是小于等于当前编号求和开出C列。这时C列如果数据一样表明连号,如果出现一次表明不连号
- 第五步,根据分组后的数据group by然后汇总,记得加一个条件,分组个数要大于1,证明是多个连号
6.效果、代码如下: