[Oracle] ADD_MONTHS()函数

ADD_MONTHS() 是 Oracle 中专门用于日期计算的函数,它可以在给定日期上增加或减少指定的月数

ADD_MONTHS()函数特别适合需要精确处理月份增减的业务场景

语法格式

sql 复制代码
ADD_MONTHS(date, number_of_months)

参数说明

date: 基准日期(DATE 类型)

number_of_months: 要添加的月数,可以是整数或小数(小数部分会被忽略)

正数:向未来计算

负数:向过去计算

示例

sql 复制代码
-- 当前日期加2个月
SELECT ADD_MONTHS(SYSDATE, 2) FROM dual;

-- 当前日期减3个月
SELECT ADD_MONTHS(SYSDATE, -3) FROM dual;

-- 月末处理
-- 如果基准日期是某月的最后一天,结果也会是该月的最后一天
SELECT ADD_MONTHS(TO_DATE('2025-01-31', 'YYYY-MM-DD'), 1) FROM dual;  -- 2025/2/28

-- 自动处理跨年份的月份计算
SELECT ADD_MONTHS(TO_DATE('2025-11-15', 'YYYY-MM-DD'), 3) FROM dual;  -- 2026/2/15

-- 保留日期部分
-- 结果会保留原始日期的时分秒部分
SELECT ADD_MONTHS(TO_DATE('2025-08-09 14:30:00', 'YYYY-MM-DD HH24:MI:SS'), 1) FROM dual;  -- 2025/9/9 下午 02:30:00

-- 与TRUNC()函数结合使用
-- 去年同月第一天
SELECT ADD_MONTHS(TRUNC(SYSDATE, 'MM'), -12) FROM dual;

提示Tips

① 月数(包含小数)会被截断取整(不四舍五入)

sql 复制代码
-- 等同于 ADD_MONTHS(SYSDATE, 1)
SELECT ADD_MONTHS(SYSDATE, 1.9) FROM dual;
相关推荐
YOU OU8 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng9 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿9 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-9 小时前
Redis 命令
数据库·redis·缓存
小江的记录本10 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`10 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存
二宝哥11 小时前
离线安装maven
java·数据库·maven
SZLSDH11 小时前
场景适配论 | 数字孪生IOC建设中渲染技术与智能体能力的协同逻辑
前端·数据库·ai·数字孪生·数据可视化·智能体
这个DBA有点耶11 小时前
SQL改写实战:子查询、CTE、窗口函数性能对比
数据库·mysql·性能优化
@我漫长的孤独流浪11 小时前
数据库完整性约束全解析:从理论到实践
数据库