【SQL题目】连续日期的判断

【1.查询至少连续3天下单的用户】

思路1(使用lead):

  1. distinct user_id,create_date去重,确保每个用户每天只有一条访问记录
  2. lead(create_date,2,‘9999-12-31’) over(partition by user_id order by create_date)根据用户分区,订单日期排序,取后2行的订单日期(取不到则返回’9999-12-31’)
  3. 用datediff计算【订单日期】与【后2行订单日期】的差值,如果等于2则说明存在连续3天下单
    在这里插入图片描述
  4. 筛选出datediff等于2的记录,distinct user_id即可

思路2(使用row_number):

  1. distinct user_id,create_date去重,确保每个用户每天只有一条访问记录
  2. row_number() over(partition by user_id order by create_date)按用户分区,按访问日期排序,添加序号
  3. 每个日期与序号相减获得一个新的日期
    在这里插入图片描述
  4. group by user_id,diff对用户和新的日期进行分组,然后count()统计日期,判断count() >=3
    在这里插入图片描述

【2. 用户登录日志表user_id,visit_date 用sql查询出近30天连续访问7天以上的用户数量】
思路:

  1. 筛选近30天每个用户的访问记录,并去重确保同一个用户当天只有一条记录
  2. 对用户分组按访问日期排序,添加序号
  3. 每条记录的访问日期与对应的序号相减,获得一个新的日期字段
  4. group by用户,新的日期字段,统计个数,having筛选大于等于7
select user_id,diff,count(*) as cnt
from
(
	select 
	user_id,
	visit_date,
	date_sub(visit_date,row_number() over(partition by user_id order by visit_date)) as diff
	from 
	(
		select distinct user_id,visit_date 
		from table 
		where visit_date >= date_sub(current_date,30)
	) t1
) t2
group by user_id,diff
having cnt >= 7

相关推荐

  1. SQL-取连续日期或者数值

    2023-12-24 08:54:02       53 阅读
  2. 日期判断输出

    2023-12-24 08:54:02       33 阅读
  3. SQL连续

    2023-12-24 08:54:02       72 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-24 08:54:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-24 08:54:02       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-24 08:54:02       87 阅读
  4. Python语言-面向对象

    2023-12-24 08:54:02       96 阅读

热门阅读

  1. API 接口怎样设计才安全?

    2023-12-24 08:54:02       66 阅读
  2. 装箱和拆箱(js的问题)

    2023-12-24 08:54:02       55 阅读
  3. nginx单域名配置访问多vue项目(vue3 + vite4)

    2023-12-24 08:54:02       57 阅读
  4. 前端基础vue路由懒加载

    2023-12-24 08:54:02       51 阅读
  5. Ubuntu2204配置samba

    2023-12-24 08:54:02       75 阅读
  6. (五)Python 垃圾回收机制

    2023-12-24 08:54:02       50 阅读
  7. servlet+thymeleaf改良版

    2023-12-24 08:54:02       62 阅读
  8. 一款C++编写的数据可视化库Matplot++

    2023-12-24 08:54:02       64 阅读
  9. 微信小程序 上列表拉加载下拉刷新

    2023-12-24 08:54:02       63 阅读