欢迎投稿

今日深度:

MySQL中data_sub()函数定义和用法,

MySQL中data_sub()函数定义和用法,


目录
  • MySQL DATE_SUB() 函数
    • 定义和用法
      • 语法

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中data_sub()函数的文章就介绍到这了,更多相关MySQL data_sub()函数内容请搜索PHP之友以前的文章或继续浏览下面的相关文章希望大家以后多多支持PHP之友!

您可能感兴趣的文章:
  • mysql中日期的加减 date_add()、date_sub() 函数及用法小结

www.htsjk.Com true http://www.htsjk.com/Mysql/47502.html NewsArticle MySQL中data_sub()函数定义和用法, 目录 MySQL DATE_SUB() 函数 定义和用法 语法 MySQL DATE_SUB() 函数 定义和用法 DATE_SUB() 函数从日期减去指定的时间间隔。 语法 DATE_SUB (date,INTERVAL expr type) date参...
评论暂时关闭