SQL面试题每日一题之求解用户最长连续登录天数

SQL面试题每日一题之求解用户最长连续登录天数

之后会不定期更新每日一题sql系列。

SQL面试题每日一题系列内容均来自于网络以及实际使用情况收集,如与各大厂面试题有雷同,纯属巧合。

1.题目

问题:以下为多个用户每日登录记录数据,求解每个用户最长连续登录天数。

该问题为此还会衍生出,标记处连续登录n天用户。用户连续登录中出现的所有未登录日期等。具体之后进行分析计算演示,欢迎持续关注。

2.基础数据准备

create table if not exists temp.user_login_log (`id` bigint comment '用户id',`login_date` string comment '登录日期'
) comment '用户每日登录流水'

数据预览

idlogin_date
12024-04-25
12024-04-26
12024-04-27
12024-04-28
12024-04-30
12024-05-01
12024-05-02
12024-05-04
12024-05-05
12024-05-06
12024-05-07
22024-04-25
22024-04-28
22024-05-01
22024-05-03
22024-05-04

3.问题分析

求解每个用户最长连续登录天数,考察的是对日期加减函数的使用以及对排序开窗函数的应用。排序开窗函数详见SQL窗口分析函数使用详解系列二之分组排序窗口函数

维度评分
题目难度⭐️⭐️⭐️⭐️
题目清晰度⭐️⭐️⭐️⭐️
业务常见度⭐️⭐️⭐️⭐️⭐️

4.解题SQL

1.对原始数据排序生成序号

这步很重要,作为判断是否连续的基础数据处理。

select id,login_date,row_number() over(partition by id order by login_date) as rank_id 
from temp.user_login_log
order by id,login_date

数据结果

idlogin_daterank_id
12024-04-251
12024-04-262
12024-04-273
12024-04-284
12024-04-305
12024-05-016
12024-05-027
12024-05-048
12024-05-059
12024-05-0610
12024-05-0711
22024-04-251
22024-04-282
22024-05-013
22024-05-034
22024-05-045

可以看到这里是按用户id分组,按日期进行了一个分别排序。

2.对排序进行做差值

因为如果是连续登录,那登录日期减去自增的排序就会始终是一个日期值。比如3号登录排序1,4号登录排序2,5号登录排序3。则他们之间的差值都是2。这就是连续。反之,如果差值不一致,就是不连续。

select id,login_date,date_sub(login_date,rank_id) as date_gap 
from (select id,login_date,row_number() over(partition by id order by login_date) as rank_id from temp.user_login_log
) a
order by id,login_date

数据结果

idlogin_datedate_gap
12024-04-252024-04-24
12024-04-262024-04-24
12024-04-272024-04-24
12024-04-282024-04-24
12024-04-302024-04-25
12024-05-012024-04-25
12024-05-022024-04-25
12024-05-042024-04-26
12024-05-052024-04-26
12024-05-062024-04-26
12024-05-072024-04-26
22024-04-252024-04-24
22024-04-282024-04-26
22024-05-012024-04-28
22024-05-032024-04-29
22024-05-042024-04-29

可以看到连续登录的日期的记录其求解的date_gap是相同的,这时候大多人都能反应过来,求解最长连续登录天数,接下来只要按date_gap分组计数,然后求个最大值就可以了。

3.按date_gap分组计数

select id,date_gap,count(0) as login_day from (select id,login_date,date_sub(login_date,rank_id) as date_gap from (select id,login_date,row_number() over(partition by id order by login_date) as rank_id from temp.user_login_log) a
) b 
group by id,date_gap
order by id,date_gap

数据结果

iddate_gaplogin_day
12024-04-244
12024-04-253
12024-04-264
22024-04-241
22024-04-261
22024-04-281
22024-04-292

连续登录天数login_day 一目了然了。

4.分组求最长连续登录天数

select id,max(login_day) as max_login_day from (select id,date_gap,count(0) as login_day from (select id,login_date,date_sub(login_date,rank_id) as date_gap from (select id,login_date,row_number() over(partition by id order by login_date) as rank_id from temp.user_login_log) a) b group by id,date_gap
) c
group by id
order by id

数据结果

idmax_login_day
14
22

用户1最长登录天数为4天,用户2最长登录天数为2天。

5.衍生问题解答

如果求解的不是最长连续登录天数,而是连续登录n天的所有记录呢?

可以考虑用lead()函数尝试求解。

下期进行完整解答。

以上,本期全部内容。

感谢阅读。

按例,欢迎点击此处关注我的个人公众号,交流更多知识。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/8390.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

microsoft的azure语音,开发环境运行正常,发布到centos7线上服务器之后无法运行解决方案

最近在做AI语音对话的功能,用到了azure的语音语音服务,开发的时候还算顺利,部署到线上后,发现在正式服上无法完成语音转文本的操作,提示: org.springframework.web.util.NestedServletException: Handler …

浅谈Windows 上的线程亲和性(Thread affinity)

​ 前言 线程属性包括是否分离、亲和性、调度策略和优先级等。Linux默认的调度策略是CFS(完全公平调度算法),而 Windows 是基于优先级抢占式的策略。 在这些方面,Windows 和 Linux 差异巨大。本文仅针对 Windows 系统的线程亲和性进行探讨。 线程亲和性(Thread affinity) 什…

Softmax和Sigmoid

Softmax和Sigmoid函数在机器学习和深度学习中都扮演着重要的角色,但它们在功能和应用上存在一些关键的区别。 功能和应用领域: Softmax函数:主要用于多分类问题。它将一组实数(通常是神经网络的输出)转换为一组概率分…

手游广告归因新选择:Xinstall助力精准衡量投放效果

在手游市场竞争日益激烈的今天,广告主们面临着如何精准衡量广告投放效果的难题。手游广告归因平台的出现,为广告主们提供了一种全新的解决方案。而Xinstall,作为其中的佼佼者,正以其独特的优势,助力广告主们破解这一难…

​The Sandbox VoxEdit 迷你创作比赛|春天的资产

VoxEdit 迷你比赛 我们将为您带来一场新的 VoxEdit 迷你比赛!在为期 8 天的比赛中,您将有机会快速创建并展示您的可用资产。 立即下载 VoxEdit 并开始参赛吧: The Sandbox - VoxEdit 比赛主题: 设计与春季环境相关的资产。本次比…

前端高频面试题 5.08

事件委托 事件委托是前端开发中常用的一种优化性能和代码可维护性的方法,它基于DOM的事件冒泡机制。当一个元素触发事件时,这个事件会按照从顶层到底层的顺序传播,直到最底层的元素(通常是文档的根节点)。事件委托利用…

第1章. STM32单片机入门知识介绍

目录 0. 《STM32单片机自学教程》专栏 1.1 嵌入式系统简介 1.1.1 什么是嵌入式系统 1.1.2 嵌入式系统的特点 1.1.3 嵌入式系统的应用领域 1.2 单片机基本概念 1.3 ARM简介 1.3.1 ARM公司简介 1.3.2 ARM处理器简介 1.4 STM32简介 1.4.1 基于Cortex内核的MCU 1.4.…

分红76.39亿,分红率再创新高,成长活力无限的伊利带来丰厚回报

伊利47万股东,又等来了一个好消息。 4月29日,伊利股份发布2023年报,实现营业总收入1261.79亿元,归母净利润104.29亿元,双创历史新高,实现连续31年稳健增长。 在递交亮眼成绩单的同时,乳业巨头伊…

头歌实践教学平台:CG3-v2.0-图形几何变换

第3关:图形的平移与旋转 一. 任务描述 1. 本关任务 (1) 理解几何变换基本原理, 掌握平移和旋转变换的方法; (2) 根据几何变换基本原理,将main函数中的空白部分补充完整。 2. 输入 (1) 代码将自动输入一个边长为2的obj正方体模型,具体模型如下图&…

DDR4 SDRAM 和LPDDR4的区别

DDR4 SDRAM(Double Data Rate Fourth Generation Synchronous Dynamic Random-Access Memory)和LPDDR4(Low Power Double Data Rate Fourth Generation)都是内存技术的标准,但它们设计用于不同的平台,并在性能、功耗和物理尺寸方面有所差异: 应用领域: DDR4 SDRAM 主要…

【力扣】746. 使用最小花费爬楼梯

原题链接:. - 力扣(LeetCode) 目录 1. 题目描述 2. 思路分析 3. 代码实现 1. 题目描述 给你一个整数数组 cost ,其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用,即可选择向上爬一个或者…

Unity图文混排EmojiText的使用方式和注意事项

​​​​​​​ 效果演示: 使用方式: 1、导入表情 2、设置图片格式 3、生成表情图集 4、创建/修改目标材质球 5、测试 修复换行问题 修复前: 修复后: 修复代码: 组件扩展 1、右键扩展 2、组件归类&#…

ODBC - 笔记

0 C++通过ODBC方式连接数据库SQLServer及增删查改操作【图书借阅系统为例】 C++通过ODBC方式连接数据库SQLServer及增删查改操作【图书借阅系统为例】_odbc5.2 c++怎么连接数据库-CSDN博客 0.1 c++使用libODBC linux - /lib/x86_64-linux-gnu/libodbc.so.2 win - /c/WINDO…

【MySQL数据库设计规范】安全规范

欢迎点开这篇文章,自我介绍一下哈,本人笔名姑苏老陈,是一个JAVA开发老兵。 本文收录于 《MySQL数据库设计规范》专栏中,该专栏主要分享一些关于MySQL数据库设计相关的技术规范文章,定期更新,欢迎关注&#…

ansible-3

目录 一、Templates 模块 1.1.先准备一个以 .j2 为后缀的 template 模板文件,设置引用的变量 1.2.修改主机清单文件,使用主机变量定义一个变量名相同,而值不同的变量 1.3.编写 playbook 二、tags 模块 三、Roles 模块 四、编写模块 4…

环形链表问题详解

引言 环形链表的题大家都应该做过,如果没有做过可以去某扣上做一下 ,下面有传送门 141. 环形链表 - 力扣(LeetCode)https://leetcode.cn/problems/linked-list-cycle/submissions/530160081/ 正文 如果在面试的情况下出现了环形链表的题大…

【PHP】计算两个时间戳之间相差的时间

目录 一、span方法概述 二、输出格式解析 三、方法执行流程 四、应用场景 五、注意事项 六、完整代码示例 时间跨度计算:PHP中的span方法解析 在Web开发中,我们经常需要对时间进行各种计算,尤其是在用户界面中展示时间差或倒计时等功能…

iOS 10权限问题

简单说明 1.注意需要打开info.plist文件添加相应权限以及权限的说明,否则程序在iOS10上会出现崩溃。 2.且添加时注意不要有空格。 3.输入Privacy一般会有提示。 权限说明 iOS 10支持的所有权限类型 Privacy - Bluetooth Peripheral Usage Description 蓝牙权限…

43.乐理基础-拍号-常见的拍号与强弱关系

首先拍号的定义:39.认识音符、40.什么是一拍、41.小节、小节线、终止线、42.看懂拍号的意义 通过 39.认识音符、40.什么是一拍、41.小节、小节线、终止线、42.看懂拍号的意义 应该可以知道 Y的取值只能是2、4、8、16、32、64。。。。因为Y指的是Y分音符,…

【ITK配准】第八期 优化器(Optimizer)

很高兴在雪易的CSDN遇见你 VTK技术爱好者 QQ:870202403 公众号:VTK忠粉 前言 本文分享ITK中的优化器(Optimizer),希望对各位小伙伴有所帮助! 感谢各位小伙伴的点赞+关注,小易会继续努力分享,一起进步! 你的点赞就是我的动力(^U^)ノ~YO 优化器 在ITK中最…