MySQL DATE_SUB() 函数
定义和用法
DATE_SUB() 函数从日期减去指定的时间间隔。
语法
DATE_SUB (date,INTERVAL expr type)
date 参数是合法的日期表达式。expr 参数是您希望添加的时间间隔,或者属性名称。
type 参数可以是下列值:
| Type 值 |
|---|
| MICROSECOND 微秒,表示时间的最小单位,1秒等于1000000微秒。 |
| SECOND 秒,表示时间中的秒数。 |
| MINUTE 分钟,表示时间中的分钟数。 |
| HOUR 小时,表示时间中的小时数。 |
| DAY 天,表示时间中的天数。 |
| WEEK 周,表示时间中的周数。 |
| MONTH 月,表示时间中的月数。 |
| QUARTER 季度,表示时间中的季度数(一个季度等于3个月)。 |
| YEAR 年,表示时间中的年数。 |
| SECOND_MICROSECOND 秒和微秒。 |
| MINUTE_MICROSECOND 分钟和微秒。 |
| MINUTE_SECOND 分钟和秒。 |
| HOUR_MICROSECOND 小时和微秒。 |
| HOUR_SECOND 小时和秒。 |
| HOUR_MINUTE 小时和分钟。 |
| DAY_MICROSECOND 天和微秒。 |
| DAY_SECOND 天和秒。 |
| DAY_MINUTE 天和分钟。 |
| DAY_HOUR 天和小时。 |
| YEAR_MONTH 年和月。 |
我们使用下面的 SELECT 语句:
SELECT OrderId, data_sub(OrderDate,INTERVAL 2 DAY) AS OrderPayDate FROM Orders整个SQL查询的目的是选择"Orders"表中的"OrderId"列、以及通过在"OrderDate"列中减去2天得到的新日期,新日期被命名为"OrderPayDate"。
select author_id,answer_date, row_number() over (partition by author_id order by answer_date) as rn, date_sub(answer_date,interval (row_number() over (partition by author_id order by answer_date)) day) as dt2 from answer_tb group by answer_date, author_id使用了窗口函数
row_number()来为每个author_id分区内的记录计算行号,使用
date_sub()函数,从answer_date减去相应的天数,这个天数是由上面计算的行号决定,也就是减去行号,从而来生成一个新的日期。最终的结果被命名为dt2。
本文详细解释了MySQL中的DATE_SUB()函数,用于从日期中减去指定的时间间隔,通过示例展示了如何在SQL查询中使用此函数,包括与窗口函数row_number()的结合应用。
1万+

被折叠的 条评论
为什么被折叠?



