第一:时间相加(对于day、hour、minute、second使用的是numtodsinterval函数,方法和numtoyminterval一样。后面可以跟变量)
select numtodsinterval(10, 'day') + numtodsinterval(2, 'hour') +
numtodsinterval(3, 'minute') + numtodsinterval(2.3312, 'second')
from dual
+000000010 02:03:02.331200000
第二:使用dump函数可以查看每一行的内部存数结构。
SQL> select cola,dump(cola) from test_char;
a Typ=96 Len=10: 97,32,32,32,32,32,32,32,32,32
aa Typ=96 Len=10: 97,97,32,32,32,32,32,32,32,32
aaa Typ=96 Len=10: 97,97,97,32,32,32,32,32,32,32
aaaa Typ=96 Len=10: 97,97,97,97,32,32,32,32,32,32
aaaaaaaaaa Typ=96 Len=10: 97,97,97,97,97,97,97,97,97,97
Typ=96 表示数据类型的ID。Oracle为每一种数据类型都进行了编号。说明char类型的编号是96.
Len =10 表示所在的内部存储的长度(用字节表示)。虽然第一例只存了一个字符’a’,但是它还是占用了10个字节的空间。
97,32,32,32,32,32,32,32,32,32 表示内部存储方式。可见oracle的内部存储是以数据库字符集进行存储的。
97正好是字符a的ASCII码。
可以使用chr函数把ASCII码转成字符。
SQL> select chr(97) from dual;
C
-
a
第三 规则
Numtodsinterval(n, 'second') 获得秒的时间间隔
Numtodsinterval(n, 'minute') 获得分的时间间隔
Numtodsinterval(n, 'month') 获得月的时间间隔
Numtodsinterval(n, 'year') 获得月的时间间隔
增加月份时要非常的小心,应该使用add_months函数。为什么呢?
比如当前日期为2000-2-29日。增加一个月得到的日期就应该是2000-3-31
如果只是简单的加30天或加31天,是无法实现的。所以必须使用add_months函数,它会自动来处理这种月末问题。对年份进行增加也会出现类似的问题
第四:interval的使用
SQL> select sysdate +interval '+3' month from dual;
SYSDATE+INTERV
--------------
01-12月-11
SQL> select sysdate +interval '+2' month from dual;
SYSDATE+INTERV
--------------
01-11月-11
SQL> select to_date('2007-02-28','yyyy-mm-dd')+interval '+3' month from dual;
TO_DATE('2007-
--------------
28-5月 -07