在MySQL中,adddate(date, interval expr unit) 函数用于向一个日期时间值添加指定的时间间隔,并返回计算后的新日期时间。
其语法格式如下:
adddate(date, interval expr unit) --返回日期加上间隔后的结果
adddate()函数根据日期时间参数和时间间隔参数,返回计算后的新日期时间,让我们通过下表来理解其参数设计:
| 参数 | 说明 |
|---|---|
| date | 基准日期/时间,支持 DATE、DATETIME、TIMESTAMP 类型 示例: '2025-01-01', NOW(), 20250101000000 |
| INTERVAL | 固定关键字,表示后面跟的是时间间隔 |
| expr | 时间长度表达式: - 可以是正数或负数 - 支持纯数字: 5, -3, 2.5- 支持数学表达式: 5*2, 10/2- 对于组合单位需用字符串: '1-2', '2:30:45' |
| unit | 时间单位: - 基本单位:YEAR, MONTH, DAY, HOUR, MINUTE, SECOND, WEEK, QUARTER - 组合单位:YEAR_MONTH, DAY_HOUR, HOUR_MINUTE, MINUTE_SECOND, DAY_SECOND, HOUR_SECOND |
值得注意的是,adddate(NULL, interval expr unit) 的返回值是NULL;对于非字符串参数,adddate() 函数会尝试将其转换为日期时间,然后进行计算;对于字符串参数,如果其格式有效则正常计算,如果格式无效则返回NULL。
下面,我们将通过示例展示 adddate() 函数的使用方法:
select adddate('2025-11-20', interval 7 day);
select adddate(2025-11-20, interval 1 month);
select adddate(now(), interval 2 hour);
select adddate(NULL, interval 1 day);
select adddate('dotcpp', interval 1 day);其查询结果如下:

总结:在MySQL中,我们可以通过 adddate() 函数灵活地对一个日期时间进行加减运算。
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程