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

学校要求做网站硬件开发入门

学校要求做网站,硬件开发入门,wordpress信息分类系统主题,2345网址导航高级版力扣题 1、题目地址 1709. 访问日期之间最大的空档期 2、模拟表 表:UserVisits Column NameTypeuser_idintvisit_datedate 该表没有主键,它可能有重复的行该表包含用户访问某特定零售商的日期日志。 3、要求 假设今天的日期是 ‘2021-1-1’ 。 …

力扣题

1、题目地址

1709. 访问日期之间最大的空档期

2、模拟表

表:UserVisits

Column NameType
user_idint
visit_datedate
  • 该表没有主键,它可能有重复的行
  • 该表包含用户访问某特定零售商的日期日志。

3、要求

假设今天的日期是 ‘2021-1-1’ 。

编写解决方案,对于每个 user_id ,求出每次访问及其下一个访问(若该次访问是最后一次,则为今天)之间最大的空档期天数 window

返回结果表,按用户编号 user_id 排序。

结果格式如下示例所示:

示例 1:

输入:
UserVisits 表:

user_idvisit_date
12020-11-28
12020-10-20
12020-12-3
22020-10-5
22020-12-9
32020-11-11

输出:

user_idbiggest_window
139
265
351

解释:

对于第一个用户,问题中的空档期在以下日期之间:

  • 2020-10-20 至 2020-11-28 ,共计 39 天。
  • 2020-11-28 至 2020-12-3 ,共计 5 天。
  • 2020-12-3 至 2021-1-1 ,共计 29 天。

由此得出,最大的空档期为 39 天。
对于第二个用户,问题中的空档期在以下日期之间:

  • 2020-10-5 至 2020-12-9 ,共计 65 天。
  • 2020-12-9 至 2021-1-1 ,共计 23 天。

由此得出,最大的空档期为 65 天。
对于第三个用户,问题中的唯一空档期在 2020-11-11 至 2021-1-1 之间,共计 51 天。

4、代码编写

Lead (列名) 语法

SELECT user_id, MAX(biggest_window) AS biggest_window
FROM (SELECT *, DATEDIFF(IFNULL(Lead(visit_date) over (partition by user_id order by visit_date), '2021-1-1'), visit_date) AS biggest_windowFROM UserVisits
) AS one
GROUP BY user_id

如果加 IFNULL

SELECT *, DATEDIFF(IFNULL(Lead(visit_date) over (partition by user_id order by visit_date), '2021-1-1'), visit_date
) AS biggest_window
FROM UserVisits
| user_id | visit_date | biggest_window |
| ------- | ---------- | -------------- |
| 1       | 2020-10-20 | 39             |
| 1       | 2020-11-28 | 5              |
| 1       | 2020-12-03 | 29             |
| 2       | 2020-10-05 | 65             |
| 2       | 2020-12-09 | 23             |
| 3       | 2020-11-11 | 51             |

如果不加 IFNULL,还需要特别处理

SELECT *, DATEDIFF(Lead(visit_date) over (partition by user_id order by visit_date),  visit_date
) AS biggest_window
FROM UserVisits
| user_id | visit_date | biggest_window |
| ------- | ---------- | -------------- |
| 1       | 2020-10-20 | 39             |
| 1       | 2020-11-28 | 5              |
| 1       | 2020-12-03 | null           |
| 2       | 2020-10-05 | 65             |
| 2       | 2020-12-09 | null           |
| 3       | 2020-11-11 | null           |

Lead (列名, 偏移量, 超出记录窗口时的默认值) 语法

SELECT user_id, MAX(biggest_window) AS biggest_window
FROM (SELECT *, DATEDIFF(Lead(visit_date, 1, '2021-01-01') over (partition by user_id order by visit_date), visit_date) AS biggest_windowFROM UserVisits
) AS one
GROUP BY user_id

以前文章

【MySQL】窗口函数 Lead 和 Lag 的运用(MySQL版本8+)以及 时间差函数 TIMESTAMPDIFF 的运用

http://www.yayakq.cn/news/630931/

相关文章:

  • 北京天润建设工程有限公司网站做外贸的网站简称为什么网站
  • 原材料价格查询网站2022新闻热点事件简短30条
  • 纪检监察网站建设情况汇报黄冈推广平台
  • 医疗网站的运营汕头龙湖网站建设
  • 百度网站优化外包增加wordpress阅读量
  • 重庆购物网站建设网站开发与rest
  • 装饰公司网站建设流程网站建设 网站优化营销型网站建设专家
  • 东莞黄江做网站公司网页打不开视频
  • 虚拟机 网站建设wordpress首页多样式
  • 集团网站 备案仿win8 网站模版
  • 北京市建设工程教育考试网站Centos建网站必须域名
  • 响应式网站建设论文网页转向功能网站
  • 北京二手房网站中国商标商标查询网
  • 网站开发维护花费阳江网站网站建设
  • 事件网站推广门户网站栏目建设
  • 萝岗手机网站建设软件开发工程师证书有用吗
  • 做购物网站能否生存flash个人网站动画
  • 外国建筑网站福州关键词自动排名
  • 城阳 网站建设哪些官网用wordpress
  • 青浦做网站公司主流大型网站开发语言调查
  • 178网站建设大庆医院网站建设
  • 黑龙江 网站开发鼓楼区建设房产和交通局网站
  • 大同网站建设网页升级访问紧急大通知狼
  • 做网站用asp div代码如何用front做网站网页
  • 河南省南水北调建设管理局网站平面设计要素
  • 临漳网站建设wordpress 使用 mysqli
  • 微信微商城平台德州乐陵德州seo公司
  • 建设网站360学院网站设计模板
  • 企业网站建设中什么二手车网站做最好
  • 婚恋网站做期货现货贵金属的人外国食品优秀设计网站