详细解说MySQL中data_sub()函数

打印 上一主题 下一主题

主题 537|帖子 537|积分 1611

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 语句:
     
  1. SELECT
  2.    OrderId,
  3.    data_sub(OrderDate,INTERVAL 2 DAY) AS OrderPayDate
  4. FROM Orders
复制代码
  
  1. 整个SQL查询的目的是选择"Orders"表中的"OrderId"列、以及通过在"OrderDate"列中减去2天得到的新日期,新日期被命名为"OrderPayDate"。
复制代码
    
  1. select
  2.    author_id,answer_date,
  3.    row_number() over (partition by author_id order by answer_date) as rn,
  4.    date_sub(answer_date,interval (row_number() over (partition by author_id order by answer_date)) day) as dt2
  5. from answer_tb
  6. group by answer_date, author_id
复制代码
使用了窗口函数 row_number() 来为每个 author_id 分区内的记录计算行号,
  使用 date_sub() 函数,从 answer_date 减去相应的天数,这个天数是由上面计算的行号决定,也就是减去行号,从而来生成一个新的日期。最终的效果被命名为 dt2。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

惊落一身雪

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表