INTERVAL数据类型用来存储两个时间戳之间的时间间隔。可以指定years and months,或者days,hours,minuts,seconds之间的间隔。
ORACLE支持两种INTEVAL类型,它们分别是YEAR TO MONTH和DAY TO SECOND。每个类型都包含leading field和trailing field。主参数定义要被计算的date或者time,副参数定义最小增长量。 一、INTERVAL YEAR TO MONTH
声明INTERVAL YEAR TO MONTH的语法是:
其中:
DECLARE
v_inteval INTERVAL YEAR (3) TO MONTH;
BEGIN
v_inteval := INTERVAL '123-2' YEAR TO MONTH;
DBMS_OUTPUT.put_line (v_inteval);
END;
结果为:+123-02。说明:表示123年2个月。在这个例子中,必须指定YEAR,即leading field的精度(percision),因为默认值为2,如果将声明部分修改为:v_inteval INTERVAL YEAR TO MONTH;会提示精度太小错误。另外,需要注意的是,声明部分需要标注精度,但是赋值部分,即v_inteval := INTERVAL '123-2' YEAR TO MONTH;不需要标注精度,如果标注,会提示语法错误。在本例中,如果精度修改为4,则结果为+0123-02。
代码二:
select INTERVAL '1234' YEAR(4) from dual;
结果为:+1234-00。说明:表示1234年0个月。因为INTERVAL类型之一,INTERVAL YEAR TO MONTH,声明时YEAR(leading field)和MONTH(trailing field)必须同时存在,否则会提示错误信息。所以,如果我们单独引用YEAR或者MONTH时,代码二的例子无法编译通过,只能通过sql语句。
类似的例子还有:
select INTERVAL '345' MONTH(3) from dual;
结果为:+28-09
例:
INTERVAL '123-2' YEAR(3) TO MONTH;
--表示: 123年2个月, "YEAR(3)" 表示年的精度为3, 可见"123"刚好为3为有效数值, 如果该处YEAR(n), n