Oracle日期加减

Oracle中日期进行加减可以使用多种方式,以下介绍三种

一种是针对天的操作,适用于对日,时,分,秒的操作,

一种是对月的操作,适用于月,年的操作,

一种是使用INTERVAL函数,适用于年,月,日,时,分,秒的操作

1.直接加减数字

 select sysdate "当前时间",sysdate+1 "当前时间加一天" from dual ;          //加一天

灵活使用

SELECT
    SYSDATE "当前时间",
    SYSDATE + 1 "加一天",
    SYSDATE + (1 / 24) "加一小时",
    SYSDATE + (1 / 24 / 60) "加一分钟",
    SYSDATE + (1 / 24 / 60 / 60) "加一秒钟",
    SYSDATE - 1 "减一天"
FROM
    dual;

查询结果如下:

2.通过ADD_MONTHS()函数

select sysdate "当前时间",ADD_MONTHS(sysdate, 1) "加一月" from dual ;     //加一个月

灵活使用

SELECT
    SYSDATE "当前时间",
    ADD_MONTHS (SYSDATE, 1) "加一月",
    ADD_MONTHS (SYSDATE, - 1) "减一月",
    ADD_MONTHS (SYSDATE, 1 * 12) "加一年",
    ADD_MONTHS (SYSDATE, - 1 * 12) "减一年"
FROM
    dual;

查询结果如下:

3.使用INTERVAL函数

语法:INTERVAL '时间差数值'  { YEAR | MONTH | DAY | HOUR | MINUTE | SECODE} (精度数值)

得出的是相应类型的时间差,注意精度数值范围是1-9,不写默认值是2,精度不匹配时间差数值会报错

例如:当前时间加1,11,111年

SELECT
    SYSDATE "当前时间",
    SYSDATE + INTERVAL '1' YEAR "加1年",                   //精度数值不写时是默认两位,此处可以写精度为1-9
    SYSDATE + INTERVAL '11' YEAR "加11年",               //此处可以不写,可以是1-9
    SYSDATE + INTERVAL '11' YEAR(2) "加11年",          // 可以写2-9
    SYSDATE + INTERVAL '111' YEAR(3) "加111年",      //此处必须写精度,精度值3-9
    SYSDATE + INTERVAL '111' YEAR (9) "加111年"     //精度值可以大于当前精度,不能小于当前数值精度,不能超过9
FROM
    dual;

查询结果:

灵活运用

SELECT
    SYSDATE "当前时间",
    SYSDATE + INTERVAL '1' YEAR "加一年",
    SYSDATE + INTERVAL '-1' YEAR "减一年",
    SYSDATE + INTERVAL '1' MONTH "加一月",
    SYSDATE + INTERVAL '1' DAY "加一天",
    SYSDATE + INTERVAL '1' HOUR "加一小时",
    SYSDATE + INTERVAL '1' MINUTE "加一分钟",
    SYSDATE + INTERVAL '1' SECOND "加一秒"
FROM
    dual;

结果如下:

精度的使用同上,当然oracle数据库对于时间大小也是有限制的,年份范围是 -4713 和 +9999 之间, 且不为 0

猜你喜欢

转载自blog.csdn.net/aaronmer/article/details/84894668