INTERVAL函数博文转载:
https://www.cnblogs.com/joechinochl/articles/5082135.html
更多内容,建议查阅上方链接博文。
interval函数:
Oracle语法:
INTERVAL 'integer[-integer]'{YEAR|MONTH}[(precision)][TO {YEAR|MONTH}]
- 该数据类型常用来表示一段时间差, 注意时间差只精确到年和月. precision为年或月的精确域, 有效范围是0到9, 默认值为2.
举例说明:
INTERVAL '123-2' YEAR(3) TO MONTH
表示: 123年2个月, "YEAR(3)" 表示年的精度为3, 可见"123"刚好为3为有效数值, 如果该处YEAR(n), n<3就会出错, 注意默认是2.
INTERVAL '123' YEAR(3)
表示: 123年0个月
INTERVAL '300' MONTH(3)
表示: 300个月, 注意该处MONTH的精度是3啊.
INTERVAL '4' YEAR
表示: 4年, 同 INTERVAL '4-0' YEAR TO MONTH 是一样的
INTERVAL '50' MONTH
表示: 50个月, 同 INTERVAL '4-2' YEAR TO MONTH 是一样
INTERVAL '123' YEAR
表示: 该处表示有错误, 123精度是3了, 但系统默认是2, 所以该处应该写成 INTERVAL '123' YEAR(3) 或"3"改成大于3小于等于9的数值都可以的
INTERVAL '5-3' YEAR TO MONTH + INTERVAL '20' MONTH =
INTERVAL '6-11' YEAR TO MONTH
表示: 5年3个月 + 20个月 = 6年11个月
sql截图:
numtodsinterval函数:
NUMTODSINTERVAL(n,‘interval_unit’)
- 将n转换成interval_unit所指定的值,interval_unit可以为day,hour,mintute,second,注意该函数不可转换成year和month。
select numtodsinterval(100,'day') from dual;
-- +000000100 00:00:00.000000000
select numtodsinterval(10,'hour') from dual;
-- +000000000 10:00:00.000000000
select numtodsinterval(10,'minute') from dual;
-- +000000000 00:10:00.000000000
select numtodsinterval(10,'second') from dual;
-- +000000000 00:00:10.000000000
sql截图:
numtoyminterval函数:
NUMTOYMINTERVAL(n,‘interval_unit’)
- interval_unit可以为year,month
举例:
select numtoyminterval(10,'year') from dual;
-- +000000010-00
select numtoyminterval(10,'month') from dual;
-- +000000000-10
sql截图: