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
相关推荐
倔强的石头_11 小时前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
zzzzzz3101 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
倔强的石头_3 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横3 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
冬奇Lab4 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence4 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神4 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据5 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_5 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡5 天前
【MySQL数据库】数据类型与表约束
数据库·mysql