Leetcode(Rising Temperature)

一、题目
这里写图片描述
输出比前一天温度高的序列号。
二、解题
1.SUBDATE()函数

SELECT wt1.Id
    FROM Weather wt1,Weather wt2
    WHERE SUBDATE(wt1.RecordDate,interval 1 day)=wt2.RecordDate
            &&  wt1.Temperature>wt2.Temperature;

解析:

  1. 因为需要与前一天的温度进行对比,所以需要命名两张表格。

  2. SUBDATE(date,INTERVAL expr type )date 参数是合法的日期表达式。expr 参数是您希望添加的时间间隔。type 参数可以是:

2.DATEDIFF()函数

SELECT wt1.Id
    FROM Weather wt1,Weather wt2
    WHERE DATEDIFF(wt1.RecordDate,wt2.RecordDate)=1
            &&  wt1.Temperature>wt2.Temperature;

解析:DATEDIFF函数返回两个日期之间的天数。
3.TO_DAYS()函数

SELECT wt1.Id
    FROM Weather wt1,Weather wt2
    WHERE TO_DAYS(wt1.RecordDate)-TO_DAYS(wt2.RecordDate)=1
            &&  wt1.Temperature>wt2.Temperature;

解析:TO_DAYS()函数返回从年份0开始的天数。
4.INNER JOIN

select a.Id 
from Weather a inner join Weather b 
on TO_DAYS(a.RecordDate)-TO_DAYS(b.RecordDate) = 1 
where a.Temperature>b.Temperature;

解析:使用内级联的方式,on后面是级联的条件。
5.级联条件不使用函数

select a.Id 
from Weather a inner join Weather b 
on a.RecordDate - interval 1 day = b.RecordDate 
where a.Temperature>b.Temperature;
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值