oracle 月份加减一个月

一、 ADD_MONTHS函数:(推荐使用)

用于在日期上增加或减少指定的月份数。

• 语法:ADD_MONTHS(date, n),其中date是要操作的日期,n是要增加或减少的月份数。如果n为负数,则表示减少月份。

• 示例:

sql 复制代码
SELECT ADD_MONTHS(SYSDATE, 2) AS two_months_later, ADD_MONTHS(SYSDATE, -3) AS three_months_ago FROM DUAL;

• 这个函数只会改变月份部分,日期部分会根据结果月份的天数进行调整。例如,如果原始日期是 2024 年 8 月 16 日,使用ADD_MONTHS(SYSDATE, 1),结果将是 2024 年 9 月 16 日;如果原始日期是 2024 年 8 月 31 日,使用ADD_MONTHS(SYSDATE, 1),结果将是 2024 年 9 月 30 日,因为 9 月只有 30 天。
二、使用 INTERVAL 表达式:(不推荐使用)

INTERVAL表达式可以用于在日期上增加或减少一定的时间间隔。

• 语法:date + INTERVAL 'n' unit或date - INTERVAL 'n' unit,其中date是要操作的日期,n是时间间隔的数量,unit是时间单位,可以是 'YEAR'(年)、'MONTH'(月)、'DAY'(日)、'HOUR'(小时)、'MINUTE'(分钟)、'SECOND'(秒)等。

• 示例:

sql 复制代码
SELECT SYSDATE + INTERVAL '2' YEAR AS two_years_later, SYSDATE - INTERVAL '3' MONTH AS three_months_ago FROM DUAL;

• 使用INTERVAL表达式可以更加灵活地进行日期的加减操作,可以指定不同的时间单位和数量。
不推荐使用原因:
如下,2024-10-31减去6个月是2024-04-31,但是4月没有31日,就会报错ORA-01839:指定月份的日期无效。

sql 复制代码
select date'2024-10-31' - INTERVAL '6' MONTH from dual;
相关推荐
一只fish几秒前
Oracle官方文档翻译《Database Concepts 26ai》第21章-Oracle AI 数据库中的AI
数据库·人工智能·oracle
Database_Cool_2 小时前
云原生多租户隔离 + 近实时分析怎么选型?阿里云 AnalyticDB MySQL 资源隔离方案
数据库·mysql·阿里云
小马爱打代码8 小时前
Redis 集群方案详解:主从复制、哨兵、脑裂、分片集群和哈希槽
数据库·redis·哈希算法
海南java第二人10 小时前
ClickHouse 稀疏索引深度解析:为什么 OLAP 数据库不用 B-Tree?
数据库·clickhouse
Litluecat10 小时前
信创迁移:Oracle切换海量数据库,慢sql扫描
数据库·sql·oracle·信创·海量
消失在人海中10 小时前
Oracle的CURRENT REDO丢失,数据丢失风险分析
数据库·oracle
喵了几个咪11 小时前
选择第三方IAM还是自建权限体系?中小型后台系统权限架构决策指南
数据库·oracle·架构
Elastic 中国社区官方博客12 小时前
Kibana:使用 AI Chat 及 MCP 轻松创建 AI 原生仪表板
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·信息可视化
杨云龙UP12 小时前
Oracle Health Check巡检脚本使用SOP V2.0:从HTML原始报告→生成Word专业巡检报告→交付客户_2026-06-03
linux·运维·数据库·sql·oracle·报告·巡检