日活中途间断一天(即员工上班第二天如果补卡也算连续)求出对应的人

select
name,fina_date,count(1) cnt 
from (select
 name,dk_date,date_add(dk_date,INTERVAL - rn day) fina_date
from 
(select
 name,dk_date,ROW_NUMBER() over(partition by name order by dk_date) rn
from
  (select
    name,
    case when rn=2 then DATE_ADD(date,INTERVAL -1 DAY) 
    else date end dk_date 
  from
    (
     select
       name,date,new_date,ROW_NUMBER() over(partition by name,date order by new_date ) rn
      
      from (
           select
             name ,date,DATE_ADD(date,INTERVAL -ra day) new_date
           from
            (select
             name,date,dense_rank() over(partition by name  order by date asc) ra
            from employee
            ) t
        )t1
      ) t2
     ) t3
    )t4
   )t5 group by name,fina_date having cnt>=7

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值