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;
相关推荐
北风toto3 分钟前
本体和智能体协同核心5步骤(生成sql语句)
数据库·sql
IvorySQL5 分钟前
PostgreSQL 技术日报 (6月10日)|多工具版本更新,PG19 图语法落地
数据库·postgresql
lsyeei10 分钟前
数据库分库分表
数据库
这个DBA有点耶13 分钟前
Vibe Coding 是什么?当“感觉编程”遇上数据库
数据库·人工智能·架构·学习方法·ai编程·程序员创富·改行学it
数智化精益手记局24 分钟前
拆解项目管理平台核心功能:看项目管理平台如何解决跨部门协作难题与多项目并行场景
大数据·运维·数据库·人工智能·产品运营
德迅云安全-小潘1 小时前
网站遭遇SQL注入攻击?应急处置、漏洞修复与长效防御完整方案
网络·sql·oracle
da-peng-song1 小时前
ArcGIS Desktop使用入门(三)图层右键工具——定义查询
数据库·arcgis·拆分数据·定义查询
热爱正能量1 小时前
数据库死锁排查思路
数据库
swordbob1 小时前
MySQL和Oracle关于读未提交的区别
数据库·mysql·oracle
林九生1 小时前
【实用技巧】MySQL 绿色版一键路径更新脚本详解 —— update_path.bat 深度解析
android·数据库·mysql