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
相关推荐
乌鸦乌鸦你的小虎牙3 小时前
qt 5.12.8 配置报错(交叉编译环境)
开发语言·数据库·qt
一只大袋鼠4 小时前
Redis 安装+基于短信验证码登录功能的完整实现
java·开发语言·数据库·redis·缓存·学习笔记
Anastasiozzzz4 小时前
深入研究Redis的ZSet底层数据结构:从 Ziplist 的级联更新到 Listpack 的完美救场
数据结构·数据库·redis
菠萝蚊鸭4 小时前
x86 平台使用 buildx 基于源码构建 MySQL Wsrep 5.7.44 镜像
数据库·mysql·galera·wsrep
沙漏无语6 小时前
(二)TIDB搭建正式集群
linux·数据库·tidb
姚不倒6 小时前
三节点 TiDB 集群部署与负载均衡搭建实战
运维·数据库·分布式·负载均衡·tidb
隔壁小邓6 小时前
批量更新方式与对比
数据库
数据知道6 小时前
MongoDB复制集架构原理:Primary、Secondary 与 Arbiter 的角色分工
数据库·mongodb·架构
人道领域6 小时前
苍穹外卖:菜品新增功能全流程解析
数据库·后端·状态模式
修行者Java6 小时前
(七)从 “非结构化数据难存储” 到 “MongoDB 灵活赋能”——MongoDB 实战进阶指南
数据库·mongodb