详细解说MySQL中data_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

相关推荐

  1. 详细解说MySQLdata_sub()函数

    2024-02-05 02:56:02       39 阅读
  2. MySQLyear()和month()函数解析与输出示例详解

    2024-02-05 02:56:02       42 阅读
  3. MySQL函数

    2024-02-05 02:56:02       35 阅读
  4. mysql函数

    2024-02-05 02:56:02       30 阅读
  5. Mysql函数

    2024-02-05 02:56:02       27 阅读
  6. MySQL 窗口函数详解

    2024-02-05 02:56:02       49 阅读
  7. MySQL的加密函数

    2024-02-05 02:56:02       58 阅读
  8. MySQL的窗口函数

    2024-02-05 02:56:02       41 阅读
  9. MySQL日期有关函数

    2024-02-05 02:56:02       47 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-05 02:56:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-05 02:56:02       101 阅读
  3. 在Django里面运行非项目文件

    2024-02-05 02:56:02       82 阅读
  4. Python语言-面向对象

    2024-02-05 02:56:02       91 阅读

热门阅读

  1. QEMU搭建Linux-ARM系统

    2024-02-05 02:56:02       53 阅读
  2. C# CAD界面介绍(一)

    2024-02-05 02:56:02       53 阅读
  3. Kotlin-类

    2024-02-05 02:56:02       53 阅读
  4. 1162. 地图分析

    2024-02-05 02:56:02       59 阅读
  5. 软件测试按照开发阶段划分5大类

    2024-02-05 02:56:02       51 阅读
  6. require.context 与 import.meta.glob

    2024-02-05 02:56:02       47 阅读
  7. 突破编程_C++_面试(基础知识(5))

    2024-02-05 02:56:02       51 阅读
  8. vue+springboot项目开发,使用MySQL示例数据库sakila

    2024-02-05 02:56:02       49 阅读
  9. MySQL十部曲之七:InnoDB索引及其优化措施

    2024-02-05 02:56:02       59 阅读
  10. day19 初始HTML

    2024-02-05 02:56:02       49 阅读
  11. NumPy基础之一维数组获取和修改元素

    2024-02-05 02:56:02       52 阅读