关注
三步:
第一步:求连续值,和lag作差=1的为0表示连续,不连续的则为1,确定断裂点
第二步:组内加合,断裂点的连续 假设原来 1 0 1 0 1,SUM之后就是 11 22 3 也就表示了前两个一组连续 3和4位连续一组,最后一个自己一组
第三步: 组内赋rank,row_number 给group内部排序,新的组新的排序,就可以了
WITH RankedDates AS (
SELECT
userid,
dt, (CASE
WHEN dt - LAG(dt) OVER(PARTITION BY userid ORDER BY dt) = 1 THEN 0
ELSE 1
END) AS NewGroupFlag
FROM table1
),
GroupedDates AS (
SELECT
userid,
dt,
SUM(NewGroupFlag) OVER(PARTITION BY userid ORDER BY dt) AS GroupNum
FROM RankedDates )
SELECT
userid,
dt,
ROW_NUMBER() OVER(PARTITION BY userid, GroupNum ORDER BY dt) AS days
FROM GroupedDates
ORDER BY userid, dt;
查看原帖
点赞 评论
相关推荐
点赞 评论 收藏
分享
10-24 18:54
南京大学 后端工程师 点赞 评论 收藏
分享
12-07 21:01
武汉大学 Java 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 找工作能把i人逼成什么样 #
14412次浏览 174人参与
# 上班到公司第一件事做什么? #
109232次浏览 736人参与
# 你今年做了几份实习? #
9575次浏览 145人参与
# 工作两年想退休了 #
203217次浏览 1795人参与
# 你开始找寒假实习了吗? #
15704次浏览 210人参与
# 新凯来求职进展汇总 #
64057次浏览 171人参与
# 影石Insta360求职进展汇总 #
166436次浏览 1335人参与
# 大厂面试初体验 #
83499次浏览 384人参与
# 0经验如何找实习? #
26795次浏览 455人参与
# 面试尴尬现场 #
205160次浏览 820人参与
# 大学最后一个寒假,我想…… #
72110次浏览 726人参与
# 25届秋招公司红黑榜 #
306588次浏览 1252人参与
# 什么样的公司千万别去 #
27910次浏览 148人参与
# 大家每天通勤多久? #
64390次浏览 415人参与
# 金融财经春招备战日记 #
43847次浏览 216人参与
# 央国企投递记录 #
165991次浏览 1622人参与
# 你找工作经历过哪些骗局? #
9627次浏览 144人参与
# 机械人值得去的半导体企业 #
32959次浏览 183人参与
# 字节出了豆包coding模型 #
6854次浏览 61人参与
# 一起聊华为 #
168438次浏览 820人参与
