mysql-sql-练习题-4-标记

标记

  • 连续登录2-7天用户
    • 建表
    • 排名找规律
  • 最大连胜次数
    • 建表
    • 只输出连胜结果
    • 输出所有连续结果

连续登录2-7天用户

在这里插入图片描述

建表

create table continuous_login(user_id1 integer comment '用户id',date_login date comment '登陆日期'
) comment '用户登录表';insert into continuous_login
values(1,'2022-01-10'),(1,'2022-01-11'),(1,'2022-01-13'),(1,'2022-01-14'),(1,'2022-01-15'),(1,'2022-01-16'),(1,'2022-01-17'),(1,'2022-01-18'),(1,'2022-01-19'),(2,'2022-01-05'),(2,'2022-01-06'),(2,'2022-01-07'),(2,'2022-01-11'),(3,'2022-01-01'),(3,'2022-01-03'),(3,'2022-01-11');

排名找规律

with tmp as(-- 过滤 保证无重复日期select *from continuous_logingroup by user_id1,date_login
),tmp1 as(-- 日期排名 等差数列select*,dense_rank() over(partition by user_id1 order by date_login) drfrom continuous_login ),tmp2 as(-- 等差 - 等差 =  差一样selectuser_id1,count(1) days_login_consecutive, -- 连续登录天数concat(min(date_login),'/',max(date_login)) date_finish_begin -- 拼接 连续登录起止日期from tmp1group by user_id1, adddate(date_login,-dr) -- 连续登录日期 等差数列having count(1) between 2 and 7 -- 连续登录所有情况中过滤出连续登录2-7天)
select -- 输出格式user_id1,group_concat(days_login_consecutive) days_login_consecutive,group_concat(date_finish_begin) date_finish_begin
from tmp2
group by user_id1;

在这里插入图片描述

最大连胜次数

在这里插入图片描述

建表

create table if not exists match1(player_id integer unsigned not null default 0 comment '玩家ID',match_day date default '1970-01-01' comment '比赛日期',result1 varchar(5) comment '比赛结果'
) comment '玩家比赛表';insert into match1
value('1','2022-01-17','Win'),('1','2022-01-18','Win'),('1','2022-01-25','Win'),('1','2022-01-31','Draw'),('1','2022-02-08','Win'),('2','2022-02-06','lose'),('2','2022-02-08','lose'),('3','2022-03-30','Win');

只输出连胜结果

with tmp as(-- 日期多次排名 找规律selectplayer_id,match_day,result1,if(result1 = 'Win',1,0) result1_if, -- if标记 为了计数dense_rank() over(partition by player_id order by match_day) dr,dense_rank() over(partition by player_id,result1 order by match_day) dr1from match1
),tmp1 as(-- 连续同种结果 差一样selectplayer_id,sum(result1_if) consecutive_countfrom tmpgroup by player_id,dr - dr1)
select -- 输出格式player_id,'Win' result1, -- 比赛结果max(consecutive_count) max_consecutive_count -- 最大连胜次数
from tmp1
group by player_id;

在这里插入图片描述

输出所有连续结果

with tmp as(-- 日期多次排名 找规律selectplayer_id,match_day,result1,dense_rank() over(partition by player_id order by match_day) dr,dense_rank() over(partition by player_id,result1 order by match_day) dr1from match1
)
select -- 连续同种结果 差一样player_id,any_value(result1) result1, -- 比赛结果count(result1) consecutive_count -- 同种结果 连续次数
from tmp
group by player_id,dr - dr1;

在这里插入图片描述

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

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

相关文章

LT2611UX四端口 LVDS转 HDMI2.0,带音频

描述LT2611UX 是一款面向机顶盒、DVD 应用的高性能 LVDS 至 HDMI2.0 转换器。LVDS输入可配置为单端口、双端口或四端口,具有1个高速时钟通道和3~4个高速数据通道,工作速率最高为1.2Gbps/通道,可支持高达19.2Gbps的总带宽。LT2611UX 支持灵活的…

002 springCloudAlibaba Sentinel流控-关联

当与A关联的资源B达到阀值后,就限流A自己 文章目录 FlowLimitController.javaSentinelServerApplication.javaServletInitializer.javaapplication.yamlpom.xmlpom.xml 启动Sentinel8080 - java -jar sentinel-dashboard-1.7.0.jar 启动微服务8401 启动8401微服务…

72、栈-每日温度

思路&#xff1a; 第一种方法&#xff0c;双循环&#xff0c;第一层循环拿出一个元素&#xff0c;第二层循环寻找最近比当前大的元素位置。 第二种方法&#xff1a;使用栈来实现。 初始化&#xff1a; int[] ans 用来存储每一天之后多少天温度会升高。Stack<Integer> 用…

Java | AI+编程 | 如何使用通义灵码提升开发效率

大家好&#xff0c;我是程序员影子 | 全网同名 一名致力于帮助更多朋友快速入门编程的程序猿 今天&#xff0c;我将以小白入门的视角带着大家学会如何在Idea上使用通义灵码&#xff0c;提高开发效率&#xff0c;减少重复工作&#xff1b;话不多说&#xff0c;我们直接进入正题…

golang beego结合wire依赖注入及自动路由

1 安装wire 1.1 通过命令直接安装 go install github.com/google/wire/cmd/wirelatest 1.2 通过go get方式安装 go get github.com/google/wire/cmd/wire进入目录编译 cd C:\Users\leell\go\pkg\mod\github.com\google\wirev0.6.0\cmd\wire go build 然后将wire.exe移动到…

广交会烹饪机器人用上大模型 支付宝小程序云提供技术支持

近日&#xff0c;第135届广交会正在火热进行&#xff0c;记者获悉&#xff0c;支付宝小程序云助力合作伙伴田螺云厨&#xff0c;在烹饪机器人上开始用上大模型技术。各类智能产品的亮相&#xff0c;从中国制造迈向中国创造&#xff0c;也成为广交会的一个亮点。 &#xff08;图…

鲲鹏华为云--OBS

文章目录 1.创建桶2.上传对象3.下载对象4.分享对象5. 删除对象6.删除桶 1.创建桶 创建桶 2.上传对象 点击创建的桶–“上传对象” 拖拽本地文件或文件夹至“上传对象”区域框内添加待上传的文件。 也可以通过单击“上传对象”区域框内的“添加文件”&#xff0c;选择本地…

C语言函数指针的使用、函数指针数组及使用、指向函数指针数组的指针,指针进阶版的冒泡排序等介绍

文章目录 前言一、函数指针的使用1. 加减乘除计算器普通实现2. 加减乘除计算机函数指针实现 二、函数指针数组1. 函数指针数组的书写2. 两个有趣的代码3. 函数指针数组的使用 三、指向函数指针数组的指针四、指针进阶_冒泡排序1.整型冒泡排序2. C语言qsort函数3. 仿写C语言qsor…

ChatGLM2-6B的部署步骤_A3

ChatGLM2-6B 下载地址 一、VisualGLM-6B环境安装 1、硬件配置 操作系统&#xff1a;Ubuntu_64&#xff08;ubuntu22.04.3&#xff09; GPU&#xff1a;4050 显存&#xff1a;16G 2、配置环境 建议最好自己新建一个conda环境 conda create -n chatglm2 python3.8pip …

【Java】HOT100 贪心算法

目录 理论基础 一、简单贪心 LeetCode455&#xff1a;分发饼干 二、中等贪心 2.1 序列问题 LeetCode376&#xff1a;摆动序列 2.2 贪心股票问题 LeetCode121&#xff1a;买卖股票的最佳时机 LeetCode121&#xff1a;买卖股票的最佳时机ii 2.3 两个维度权衡问题 LeetCode135&…

UE Snap03 启动参数设置

UE Snap03 启动参数设置 UE打包后传入自定义参数及解析。 void UGameInstance::StartGameInstance() {Super::StartGameInstance();UE_LOG(LogTemp, Warning, TEXT("--StartGameInstance--"));FString param;FParse::Value(FCommandLine::Get(), TEXT("-UserN…

美团商城代付系统源码

超火的美团代付微信小程序是一种便捷的线上支付工具&#xff0c;让用户可以方便地在微信小程序中完成美团订单的支下面是将美团代付微信小程序源码搭建的相关步骤&#xff1a; 测试网站,页面放后面&#xff0c;可以定制哦 我收了几百块就帮我另外一个客户搭建好了 搭建教程: 以…

前端VUE项目中使用async()用法是为什么?能不用吗?

使用 async 关键字来定义一个函数主要有几个原因&#xff1a; 支持 await 关键字&#xff1a; async 函数允许你在其中使用 await 关键字&#xff0c;这使得你可以在不阻塞程序执行的情况下&#xff0c;等待一个异步操作&#xff08;如网络请求、文件读写等&#xff09;的完成。…

Nutch库入门指南:利用Java编写采集程序,快速抓取北京车展重点车型

概述 在2024年北京车展上&#xff0c;电动汽车成为全球关注的焦点之一。这一事件不仅吸引了全球汽车制造商的目光&#xff0c;也突显了中国市场在电动汽车领域的领先地位。117台全球首发车的亮相&#xff0c;其中包括30台跨国公司的全球首发车和41台概念车&#xff0c;彰显了中…

长难句打卡4.29

If appropriate public policies were in place to help all women—whether CEOs or their children’s caregivers—and all families, Sandberg would be no more newsworthy than any other highly capable person living in a more just society 如果能制定适当的公共政策…

张鸣独到政治观,规矩与自信新解

张鸣独解规矩与自信&#xff0c;社政新影响揭秘。张鸣独到政治观&#xff0c;规矩与自信新解在当今社会政治的大背景下&#xff0c;学者张鸣的每一次公开演讲无疑都是一次思想的盛宴。最近&#xff0c;他就当前的社会政治问题提出了自己独特的观点&#xff0c;特别是他对规矩和…

Acrobat Pro DC 2023:专业PDF编辑软件,引领高效办公新时代

Acrobat Pro DC 2023是一款专为Mac和Windows用户设计的专业PDF编辑软件&#xff0c;凭借其强大的功能和卓越的性能&#xff0c;成为现代职场人士不可或缺的得力助手。 这款软件拥有出色的PDF编辑能力。用户不仅可以轻松地对PDF文档中的文字、图片和布局进行编辑和调整&#xf…

Go 语言变量

变量来源于数学&#xff0c;是计算机语言中能储存计算结果或能表示值抽象概念。 变量可以通过变量名访问。 Go 语言变量名由字母、数字、下划线组成&#xff0c;其中首个字符不能为数字。 声明变量的一般形式是使用 var 关键字&#xff1a; var identifier type 可以一次声…

Debian 12 tomcat 9 日志信息 中文显示乱码

问题现象&#xff1a;Debian 12 linux操作系统中&#xff0c;tomcat 9 启动日志输出 中文乱码 解决办法&#xff1a; 1、先确保系统本身就支持中文的 Debian 系统支持中文可以通过 设置locale来实现 支持中文&#xff0c;需要使用zh_CN.UTF-8字符集 Debian 系统中 可以root用…

电力能源箱3D可视化:开启智慧能源管理新篇章

随着科技的不断进步&#xff0c;电力能源箱的管理与维护逐渐向着智能化、可视化的方向发展。3D可视化技术的崛起&#xff0c;不仅极大地提升了能源管理的效率&#xff0c;更以其直观、生动的特点&#xff0c;引领着电力能源管理领域迈入了一个全新的时代。 电力能源箱作为电力系…