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

SQL-leetcode-197. 上升的温度

197. 上升的温度

表: Weather

±--------------±--------+
| Column Name | Type |
±--------------±--------+
| id | int |
| recordDate | date |
| temperature | int |
±--------------±--------+
id 是该表具有唯一值的列。
没有具有相同 recordDate 的不同行。
该表包含特定日期的温度信息

编写解决方案,找出与之前(昨天的)日期相比温度更高的所有日期的 id 。

返回结果 无顺序要求 。

结果格式如下例子所示。

示例 1:

输入:
Weather 表:
±—±-----------±------------+
| id | recordDate | Temperature |
±—±-----------±------------+
| 1 | 2015-01-01 | 10 |
| 2 | 2015-01-02 | 25 |
| 3 | 2015-01-03 | 20 |
| 4 | 2015-01-04 | 30 |
±—±-----------±------------+
输出:
±—+
| id |
±—+
| 2 |
| 4 |
±—+
解释:
2015-01-02 的温度比前一天高(10 -> 25)
2015-01-04 的温度比前一天高(20 -> 30)

题解

id 是该表具有唯一值的列。
没有具有相同 recordDate 的不同行。
该表包含特定日期的温度信息
编写解决方案,找出与之前(昨天的)日期相比温度更高的所有日期的 id 。

  • 连续对比问题如何解?
    首选lag、lead偏移函数,lag向上偏移,lead向下偏移,传参要注意,先传递偏移的字段,再传递offset偏移行,最后传递偏移不到数据的默认值,over里面传递分区+排序【多个函数并用以最后一个排序为准

方法一:lag、lead偏移函数

-- lag向上偏移
select tmp2.id as Id
from (select id,recordDate,Temperature ,lag(Temperature,1,null)  over(order by recordDate) as lag_t ,lag(recordDate,1,null) over(order by recordDate) as lag_datefrom Weather
) tmp2 where tmp2.Temperature > tmp2.lag_t
and datediff(tmp2.recordDate,lag_date)=1-- lead向下偏移[稍微麻烦点,建议优先考虑偏移对比的数据]
select tmp2.lead_id as Id
from (select id,recordDate,Temperature ,lead(Temperature,1,null)  over(order by recordDate) as lead_t ,lead(recordDate,1,null) over(order by recordDate) as lead_date,lead(id,1,null) over(order by recordDate) as lead_idfrom Weather
) tmp2 where tmp2.Temperature < tmp2.lead_t
and datediff(tmp2.recordDate,lead_date)=-1

PS:可以结合样例思考一下,体会一下窗口函数的排序效果。
看现象是以最后一个窗口函数排序为准,over啥都不写,以默认记录为准
在这里插入图片描述

方法二 join

预期是与昨天对比的结果,把昨天的数据和今天的数据拉齐不就ok了吗?
于是乎 怎么拉齐,join呗
join 一下, 把今天和昨天join起来,做下判断即可

select w1.id as Id
from Weather w1 join Weather w2
on w1.recordDate = date_add(w2.recordDate, interval 1 day)
where w1.Temperature > w2.Temperature

在这里插入图片描述
date_add 函数
interval 1 day 间隔1天
date_add(xx_date, interval 1 day) – 表示 xx_date+1
在这里插入图片描述

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

相关文章:

  • C++系列关键字static
  • 使用Fn Connect之后,如何访问到其他程序页面?原来一直都可以!
  • 探索Composable Architecture:小众但高效的现代框架技术
  • 改投论文时如何重构
  • P8打卡——YOLOv5-C3模块实现天气识别
  • 基于微信小程序的校园点餐平台的设计与实现(源码+SQL+LW+部署讲解)
  • PyTorch快速入门教程【小土堆】之完整模型训练套路
  • 【AIGC】 ChatGPT实战教程:如何高效撰写学术论文引言
  • TTL 传输中过期问题定位
  • 非docker方式部署openwebui过程记录
  • 大模型的prompt的应用二
  • ubuntu 22.04安装ollama
  • 从企业级 RAG 到 AI Assistant,阿里云 Elasticsearch AI 搜索技术实践
  • Redis--高可用(主从复制、哨兵模式、分片集群)
  • 框架(Mybatis配置日志)
  • 人工智能-Python上下文管理器-with
  • 每天40分玩转Django:Django类视图
  • 自动化测试之Pytest框架(万字详解)
  • 基于51单片机(STC32G12K128)和8X8彩色点阵屏(WS2812B驱动)的小游戏《贪吃蛇》
  • 2011-2020年各省粗离婚率数据
  • C++高级编程技巧:模板元编程与性能优化实践
  • Mac 版本向日葵退出登录账号
  • SOLIDWORKS Composer在产品设计、制造与销售中的应用
  • Win11+WLS Ubuntu 鸿蒙开发环境搭建(一)
  • [CSAW/网络安全] Git泄露+命令执行 攻防世界 mfw 解题详析
  • MySQL 锁那些事
  • Linux中常用的基本指令和一些配套的周边知识详解
  • 深入理解Java中的Set集合:特性、用法与常见操作指南
  • Oracle 使用 sql profile 固定执行计划
  • 数字电路期末复习