目录

请添加图片描述

在MySQL 5.7中,计算两个日期之间的间隔天数是一项常见的任务。

1. DATEDIFF函数

DATEDIFF函数可以直接计算两个日期之间的天数差异。

-- 计算2024年1月1日和2024年1月10日之间的天数差异
SELECT DATEDIFF('2024-01-10', '2024-01-01') AS days_difference; # 结果 9,表示两个日期之间相差9天。

2. TIMESTAMPDIFF函数

TIMESTAMPDIFF函数允许你指定日期和时间单位来计算差异,这里我们使用DAY作为单位。

-- 计算2024年1月1日和2024年1月10日之间的天数差异
SELECT TIMESTAMPDIFF(DAY, '2024-01-01', '2024-01-10') AS days_difference; # 结果 9

3. PERIOD_DIFF函数

PERIOD_DIFF函数专门用于计算两个日期之间的月份差异。

-- 计算2024年1月和2024年12月之间的月份差异
SELECT PERIOD_DIFF(202412, 202401) AS months_difference; # 结果 -11

表示从2024年1月到2024年12月相差11个月(注意结果是负数,因为第二个日期在第一个日期之后)。

4. 函数对比

下面是一个表格,对比了DATEDIFFTIMESTAMPDIFFPERIOD_DIFF这三个函数的区别:

函数

用途

单位/参数

返回值类型

DATEDIFF

计算两个日期之间的天数差异

天数

TIMESTAMPDIFF

计算两个日期/时间之间的差异,可以指定单位(如天、月、年)

指定单位

PERIOD_DIFF

计算两个日期之间的月份差异

月份

请添加图片描述

Logo

DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。

更多推荐