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;
相关推荐
m***923822 分钟前
【SQL】MySQL中的字符串处理函数:concat 函数拼接字符串,COALESCE函数处理NULL字符串
数据库·sql·mysql
!停35 分钟前
VS实用调试技巧
数据库
8***23551 小时前
在Django中安装、配置、使用CKEditor5,并将CKEditor5录入的文章展现出来,实现一个简单博客网站的功能
数据库·django·sqlite
P***84392 小时前
解决Spring Boot中Druid连接池“discard long time none received connection“警告
spring boot·后端·oracle
Token_w2 小时前
openGauss:全密态数据库的金融级安全实践
数据库·安全·金融
合作小小程序员小小店2 小时前
图书管理系统,基于winform+sql sever,开发语言c#,数据库mysql
开发语言·数据库·sql·microsoft·c#
ss2733 小时前
020:共享锁深度解析:从AQS原理到高并发实践
数据库·redis·缓存
字节拾光录3 小时前
手机号存储避坑指南:从20亿级数据库实践看,为什么VARCHAR才是终极答案
java·数据库·oracle
q***46526 小时前
Win10下安装 Redis
数据库·redis·缓存
p***92488 小时前
深入理解与实战SQL IFNULL()函数
数据库·sql·oracle