如何在MySQL中计算两个日期的间隔天数

目录

  • [1. DATEDIFF函数](#1. DATEDIFF函数)
  • [2. TIMESTAMPDIFF函数](#2. TIMESTAMPDIFF函数)
  • [3. PERIOD_DIFF函数](#3. PERIOD_DIFF函数)
  • [4. 函数对比](#4. 函数对比)

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

1. DATEDIFF函数

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

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

2. TIMESTAMPDIFF函数

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

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

3. PERIOD_DIFF函数

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

sql 复制代码
-- 计算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 计算两个日期之间的月份差异 月份
相关推荐
送秋三十五18 小时前
5分钟读懂MySQL+Redis双写一致性实现流程
数据库·redis·mysql
bbmmqq18 小时前
根据角色ID获取完整角色信息(异步)
数据库·spring·oracle
阿波罗尼亚18 小时前
查询修正字段sql记录
数据库·sql·mysql
一个儒雅随和的男子18 小时前
Redis性能调优指南
数据库·redis·spring
老华带你飞18 小时前
动漫资讯|基于Springboot的动漫交流网站设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·论文·毕设·国产动漫网站
JIngJaneIL19 小时前
机器人信息|基于Springboot的机器人门户展示系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·机器人·论文·毕设·机器人门户展示系统
QQ129584550419 小时前
ThingsBoard部件数据结构解析
数据结构·数据库·物联网·iot
苦学编程的谢19 小时前
Redis_1_初识Redis+浅谈分布式系统
数据库·redis·缓存
Hello.Reader19 小时前
用 Flink CDC 将 MySQL 实时同步到 Doris
大数据·mysql·flink
人工智能教学实践19 小时前
Flask-SQLAlchemy 操作 SQLite 数据库示例
数据库·sqlite·flask