当前位置: 首页 > news >正文

MySQL练手题--日期连续类型(困难)

一、准备工作

Create table If Not Exists Failed (fail_date date);
Create table If Not Exists Succeeded (success_date date);
Truncate table Failed;
insert into Failed (fail_date) values ('2018-12-28');
insert into Failed (fail_date) values ('2018-12-29');
insert into Failed (fail_date) values ('2019-01-04');
insert into Failed (fail_date) values ('2019-01-05');
Truncate table Succeeded;
insert into Succeeded (success_date) values ('2018-12-30');
insert into Succeeded (success_date) values ('2018-12-31');
insert into Succeeded (success_date) values ('2019-01-01');
insert into Succeeded (success_date) values ('2019-01-02');
insert into Succeeded (success_date) values ('2019-01-03');
insert into Succeeded (success_date) values ('2019-01-06');

表:Failed

+--------------+---------+
| Column Name  | Type    |
+--------------+---------+
| fail_date    | date    |
+--------------+---------+
该表主键为 fail_date (具有唯一值的列)。
该表包含失败任务的天数.

表: Succeeded

+--------------+---------+
| Column Name  | Type    |
+--------------+---------+
| success_date | date    |
+--------------+---------+
该表主键为 success_date (具有唯一值的列)。
该表包含成功任务的天数.

系统 每天 运行一个任务。每个任务都独立于先前的任务。任务的状态可以是失败或是成功。

编写解决方案找出 2019-01-01 到 2019-12-31 期间任务连续同状态 period_state 的起止日期(start_date 和 end_date)。即如果任务失败了,就是失败状态的起止日期,如果任务成功了,就是成功状态的起止日期。

最后结果按照起始日期 start_date 排序

返回结果样例如下所示:

示例 1:

输入:
Failed table:
+-------------------+
| fail_date         |
+-------------------+
| 2018-12-28        |
| 2018-12-29        |
| 2019-01-04        |
| 2019-01-05        |
+-------------------+
Succeeded table:
+-------------------+
| success_date      |
+-------------------+
| 2018-12-30        |
| 2018-12-31        |
| 2019-01-01        |
| 2019-01-02        |
| 2019-01-03        |
| 2019-01-06        |
+-------------------+
输出:
+--------------+--------------+--------------+
| period_state | start_date   | end_date     |
+--------------+--------------+--------------+
| succeeded    | 2019-01-01   | 2019-01-03   |
| failed       | 2019-01-04   | 2019-01-05   |
| succeeded    | 2019-01-06   | 2019-01-06   |
+--------------+--------------+--------------+
解释:
结果忽略了 2018 年的记录,因为我们只关心从 2019-01-01 到 2019-12-31 的记录
从 2019-01-01 到 2019-01-03 所有任务成功,系统状态为 "succeeded"。
从 2019-01-04 到 2019-01-05 所有任务失败,系统状态为 "failed"。
从 2019-01-06 到 2019-01-06 所有任务成功,系统状态为 "succeeded"。

 二、分析

 三、实现

with t as (                      --  连接两张表select 'succeeded' as period_state,success_date date from succeeded
union allselect 'failed' as failed,fail_date date from failed
), t1 as (                     select                       -- 对日期排序并筛选2019年时间*,row_number() over (partition by period_state order by date) rnfrom t where date between '2019-01-01' and '2019-12-31'
), t2 as (select*,date - INTERVAL rn DAY rn1   -- 时间与排序做差值,时间减去rn相应天数,时间相同的为连续from t1
), t3 as (selectperiod_state,min(date) start_date,     -- 开始时间max(date) end_date,       -- 结束时间rn1 from t2 group by period_state,rn1
)
select period_state,start_date,end_date from t3 order by start_date;  

 四、总结

本题需要自行开列,此类连续的题都可以用此方法求差值来查看差值是否相同来判断是否连续;在求差值前就必须进行开窗排序;此题中求差值必须是求出时间减去天数的时间,不可以截取时间的日来与排序作差,会出错;

http://www.lryc.cn/news/442848.html

相关文章:

  • 【AD24报错】运行DRC后出现 Un-Routed Net Constraint ### Net Not Assigned 的解决方案
  • Linux嵌入式驱动开发指南(速记版)---Linux基础篇
  • PDF——压缩大小的方法
  • 无监督神经组合优化的扩散模型框架
  • Web前端开发
  • transformer模型进行英译汉,汉译英
  • python 异步读取文件,速度变快了吗
  • 【Python】Anaconda插件:Sublime Text中的Python开发利器
  • Python酷库之旅-第三方库Pandas(123)
  • IEEE投稿 IEEE Geoscience and Remote Sensing Letters
  • 【华为杯】2024华为杯数模研赛D题 解题思路
  • Ubuntu20.04 搜索不到任何蓝牙设备
  • 【2024】MySQL账户管理
  • 轻量级流密码算法Trivium
  • MapReduce基本原理
  • 数据结构之栈(python)
  • 浅谈人工智能之基于HTTP方式调用本地QWen OPenAI接口(Java版)
  • 【python设计模式7】行为型模式2
  • 基于PHP的CRM管理系统源码/客户关系管理CRM系统源码/php源码/附安装教程
  • 【乐企】基础版接口代码实现
  • 题目--力扣----各位相加
  • git 如何基于某个分支rebase?
  • 倒序循环(一)
  • Shell篇之编写apache启动脚本
  • 头条|司法部公法局局长访谈:推进高水平公立鉴定机构建设!加快推进司法鉴定立法!
  • 高密原型验证系统解决方案(上篇)
  • 新产品,推出 MLX90372GVS 第三代 Triaxis® 位置传感器 IC,适用于汽车和工业系统(MLX90372GVS-ACE-308)
  • JAVA毕业设计178—基于Java+Springboot+vue的智能家具管理系统(源代码+数据库+万字论文)
  • 掌握 Python 异步上下文管理器
  • 当你问AI“有点烦”