Sql面试题二:请查询出用户连续三天登录的所有数据记录

问题: 现有用户登录记录表,请查询出用户连续三天登录的所有数据记录

id dt

1 2024-04-25

1 2024-04-26

1 2024-04-27

1 2024-04-28

1 2024-04-30

1 2024-05-01

1 2024-05-02

1 2024-05-04

1 2024-05-05

2 2024-04-25

2 2024-04-28

2 2024-05-02

2 2024-05-03

2 2024-05-04

期望结果:

解析:

  • 功能 :从 t3 中选择并返回所有符合条件的记录的 dt 列。t3 中的记录是那些具有符合条件的 chajv 值的行。(为了防止不同月份出现相同的差值而被分到一组,可以将id加入运算)

总结:

  1. 步骤 1 (t) :为每个 id 内的记录生成按 dt 排序的排名。
  2. 步骤 2 (t1) :计算一个新的字段 chajv,其值是 dt 中的日部分与 id(可以扩大一些倍数防止不同月份的重复) 和排名值的计算结果。
  3. 步骤 3 (t2) :统计每个 idchajv 组合出现的次数,保留那些出现次数大于或等于 3 次的组合。
  4. 步骤 4 (t3) :从 t1 中筛选出那些 chajv 值在 t2 中的记录。
  5. 最终查询 :返回这些记录中的 dt 列。

建表语句:

sql 复制代码
CREATE TABLE wo22 (
    id INT,
    dt STRING
)
ROW FORMAT DELIMITED
FIELDS TERMINATED BY ' ';  -- 假设数据是逗号分隔的
LOAD DATA LOCAL INPATH '/home/wo20.txt' INTO TABLE wo22;
sql 复制代码
with t as (
    select * ,row_number() over (partition by id order by dt) paim from wo22

),t1 as (
    select *, cast(substr(dt,9,2) as int)+cast(id as int)-paim chajv from t
),t2 as (
    select id,chajv,count(1) day from t1 group by id,chajv having day>=3)
,t3 as (
    select * from t1 where t1.chajv in (select chajv from t2)

)select dt from t3
相关推荐
CDN3606 分钟前
高防切换后网站打不开?DNS 解析与回源路径故障排查
前端·网络·数据库
笑我归无处32 分钟前
Redis和数据库的数据一致性问题研究
数据库·redis·缓存
水痕011 小时前
使用sqlSugar来操作mysql数据库
数据库·mysql
zandy10111 小时前
衡石科技 HENGSHI SENSE:一站式智能分析平台,让企业数据价值“所见即所得”
大数据·数据库·科技
fly spider1 小时前
MySQL日志篇
数据库·mysql
QC·Rex1 小时前
向量数据库对比与实战:从原理到生产落地
数据库·人工智能·向量数据库
Database_Cool_1 小时前
PolarDB分布式版 AI 助手正式上线:你的“数字DBA”已入职
数据库·阿里云·ai
一叶飘零_sweeeet1 小时前
MySQL 生产级备份与恢复全攻略:全量 / 增量 / 逻辑 / 物理备份深度拆解 + 误删数据秒级恢复实战
数据库·mysql·数据安全·数据备份
薛定谔的悦1 小时前
BMS Modbus RTU实现:从帧结构到寄存器映射的完整工程
linux·数据库·bms
light blue bird1 小时前
主从执行端动机模块工序协同组件
jvm·数据库·.net·桌面端