SQL面试题练习 —— 统计最大连续登录天数区间

目录

  • 1 题目
  • 2 建表语句
  • 3 题解

1 题目


2 建表语句


CREATE TABLE IF NOT EXISTS user_login_tb (uid INT,login_date DATE
);
insert into user_login_tb(uid, login_date) values( 1, '2022-08-02'),(1, '2022-08-03'),(2, '2022-08-03'),(2, '2022-08-04'),(2, '2022-08-05'),(2, '2022-08-05'),(3, '2022-08-05'),(2, '2022-08-06'),(4, '2022-08-06'),(4, '2022-08-07');

3 题解


WITH t AS (SELECT uid,login_date,ROW_NUMBER() OVER (PARTITION BY uid ORDER BY login_date) AS rnFROM user_login_tbgroup by uid, login_date -- 一个用户一天可能多次登录
)
SELECT part                AS days_range,COUNT(DISTINCT uid) AS user_num
FROM (SELECT uid,dd,COUNT(*) AS cnd,CASEWHEN COUNT(*) < 2 THEN '未连续登录'WHEN COUNT(*) < 4 THEN '连续登录2~3天'WHEN COUNT(*) < 8 THEN '连续登录4~7天'ELSE '连续登录大于7天'END  AS partFROM (SELECT *,DATE_SUB(login_date, rn) AS ddFROM t) t1GROUP BY uid, dd) t2
GROUP BY part
-- 记住sql的执行顺序
-- FROM -> JOIN -> ON -> WHERE -> GROUP BY -> HAVING -> SELECT -> DISTINCT -> ORDER BY -> LIMIT
ORDER BY user_num DESC;

执行结果

在这里插入图片描述

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

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

相关文章

Elasticsearch SQL:解锁Elasticsearch数据的新方式

在数据驱动的时代&#xff0c;Elasticsearch以其强大的全文搜索和实时分析能力&#xff0c;成为了处理和分析大数据的热门选择。然而&#xff0c;对于熟悉SQL语法的开发人员和数据分析师来说&#xff0c;直接使用Elasticsearch的Query DSL&#xff08;领域特定语言&#xff09;…

6个高效再利用的UI作品集设计模板

UI 作品集是指用户界面设计师的个人作品集。它展示了设计师的设计能力、技巧和风格&#xff0c;也是充分展示他们设计能力的证明。优秀的UI 作品集应具有简洁明了、美观大方、良好的互动体验和明确的目标。本文将从两个方面的介绍 Ui 作品集模板的全部内容&#xff1a;UI 作品集…

【C++11】(lambda)

C11中的lambda与线程。 目录 Lambda&#xff1a;仿函数的缺点&#xff1a;Lambda语法&#xff1a;Lambda使用示例&#xff1a;两数相加&#xff1a;两数交换&#xff1a;解决Goods排序问题&#xff1a; Lambda原理&#xff1a; Lambda&#xff1a; 假设我们有一个商品类&…

山东航空小程序查询

山东航空小程序 1) 请求地址 https://scxcx.sda.cn/mohe/proxy?url/trp/ticket/search 2) 调用方式&#xff1a;HTTP post 3) 接口描述&#xff1a; 接口描述详情 4) 请求参数: {"dep": "TAO","arr": "HRB","flightDate&qu…

ClickHouse集成LDAP实现简单的用户认证

1.这里我的ldap安装的是docker版的 docker安装的化就yum就好了 sudo yum install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin sudo systemctl start docker 使用下面的命令验证sudo docker run hello-world docker pull osixia/openl…

微信小程序与本地MySQL数据库通信

微信小程序与本地MySQL数据库通信 因为本地MySQL服务器没有域名&#xff0c;也没有进行相应的请求操作封装&#xff0c;因此微信小程序没办法和数据库通信。 但是对于开发人员来说&#xff0c;没有数据库&#xff0c;那还能干撒&#xff1f;虽然我尝试过用json-server&#x…

好用的AI搜索引擎

1. 360AI 搜索 访问 360AI 搜索: https://www.huntagi.com/sites/1706642948656.html 360AI 搜索介绍&#xff1a; 360AI 搜索&#xff0c;新一代智能答案引擎&#xff0c;值得信赖的智能搜索伙伴&#xff0c;为复杂搜索提供专业支持&#xff0c;解锁更相关、更全面的答案。AI…

数据库day2

复盘上一天的内容&#xff1a; 数据库的种类&#xff1f;你了解的数据库?什么是数据库&#xff1f; 怎么增加表中数据 &#xff0c;怎么删除表中数据&#xff0c; 怎么创建表中数据。 数据库编程的操作步骤&#xff1f; 打开数据库--增删改查--关闭数据库。 s…

探索Facebook的最新更新:社交体验的新高度

Facebook作为全球领先的社交媒体平台&#xff0c;一直致力于不断创新和改进&#xff0c;以提供更优质的用户体验。近期&#xff0c;Facebook推出了一系列新的更新&#xff0c;旨在提升用户的社交互动体验和平台功能。本文将详细探讨这些最新更新&#xff0c;分析其对用户和社交…

【cocos creator】【TS】ts入门,cocos creator基础知识

TS入门 记录常用的 系统学习可参考&#xff1a;菜鸟教程 1、语法规范&#xff1a; 以换行分割语句&#xff0c; 可省略末尾分号&#xff0c;同一行需要使用分号来分隔 2.打印log console.log("Hello World!")//白色&#xff0c;一般提示 console.warn("Hel…

如何用AI交互数字人一体机,打造政务服务新名片?

如今&#xff0c;将“高效办成一件事”作为优化政务服务、提升行政效能的重要抓手&#xff0c;各地方为了促进政务服务由传统模式向数字化、智能化方向转变&#xff0c;纷纷在政务服务场景融合了AI交互数字人&#xff0c;实现“无人化、智慧化”导办、帮办、代办等模式&#xf…

9、Redis之哨兵

Redis之哨兵 1、什么是哨兵 ​ 对于Master宕机后的冷处理方式是无法实现高可用的。Redis从2.6版本开始提供了高可用的解决方案–Sentinel哨兵机制。在集群中再引入一个节点&#xff0c;该节点充当Sentinel哨兵&#xff0c;用于监视Master的运行状态&#xff0c;并在Master宕机…

Gemma的简单理解;Vertex AI的简单理解,与chatGpt区别

目录 Gemma的简单理解 Vertex AI的简单理解 Gemma Vertex AI Gemma Vertex AI和chatcpt区别 一、定义与功能 二、技术特点 三、应用场景 四、获取与部署 Gemma的简单理解 定义与功能: Gemma是谷歌开源的一款大语言模型,它采用了Gemini架构,并提供了20亿(2B)和7…

Apache AGE的MATCH子句

MATCH子句允许您在数据库中指定查询将搜索的模式。这是检索数据以在查询中使用的主要方法。 通常在MATCH子句之后会跟随一个WHERE子句&#xff0c;以添加用户定义的限制条件到匹配的模式中&#xff0c;以操纵返回的数据集。谓词是模式描述的一部分&#xff0c;不应被视为仅在匹…

3D问界—在MAYA中使用Python脚本进行批量轴居中

问题提出&#xff1a;MAYA中如何使用Python脚本 今天不是一篇纯理论&#xff0c;主要讲一下MAYA中如何使用Python脚本&#xff0c;并解决一个实际问题&#xff0c;文章会放上我自己的代码&#xff0c;若感兴趣欢迎尝试&#xff0c;当然&#xff0c;若有问题可以见文章末尾渠道&…

分布式IO系统2通道串口通信模块M602x

现场总线耦合器本身包含一个电源模块&#xff0c;它有 2 个串口通道&#xff0c;通过 Modbus RTU&#xff08;Master&#xff09;协议连接外部串行设备&#xff0c;实现耦合器与外部串行设备通信&#xff0c;现以连接设备的示例带大家了解我们钡铼的2 通道串口通信模块 M602x。…

【BUG】已解决:Uncaught SyntaxError: Unexpected token ‘<‘

已解决&#xff1a;Could not install packages due to an EnvironmentError: [Errno 13] Permission denied 欢迎来到我的主页&#xff0c;我是博主英杰&#xff0c;211科班出身&#xff0c;就职于医疗科技公司&#xff0c;热衷分享知识&#xff0c;武汉城市开发者社区主理人 …

深入解析Apache Hive架构

目录 引言Hive简介 什么是HiveHive的特性Hive的优势 Hive架构概述 Hive的核心组件Hive的工作原理 Hive的核心组件详解 HiveQLMetaStoreDriverCompilerOptimizerExecutorStorage Hive的工作流程 查询处理流程数据加载和存储流程 Hive的使用场景Hive的优缺点总结 引言 随着大数…

【INTEL(ALTERA)】使用 F-Tile DisplayPort FPGA IP 设计示例时为何模拟失败?

目录 说明 解决方法 说明 由于 Quartus Prime Pro Edition 软件版本 24.1 存在一个问题&#xff0c;F-Tile DisplayPort FPGA IP 设计示例的模拟将运行超过 24 小时&#xff0c;然后失败&#xff0c;并显示消息“Simulation Hanged”。 解决方法 要解决此问题&#xff0c;…

Neither the JAVA_HOME nor the JRE_HOME environment variable is defined问题解决

一、系统环境变量中添加tomcatjdk的环境变量声明 1、右击此电脑->属性->高级系统设置 可复制粘贴下面的变量名 CATALINA_HOME 点击path->编辑->新建 可将下面值粘入 %CATALINA_HOME%\bin 2、配置jdk的系统变量 系统变量->新建->如图 可将下面变量名粘入 J…