分类: Oracle
2008-05-23 20:22:00
|
如果直接在SQL语句中对SYSDATE或由TO_DATE函数生成进行DUMP,会发现得到的结果与DUMP数据库中保存的日期的结果不一样。
SQL> truncate table test_date; 表已截掉。 SQL> insert into test_date values (to_date('2004-12-17 16:42:42', 'syyyy-mm-dd hh24:mi:ss')); 已创建 1 行。 SQL> col dump_date format a65 DAT DUMP_DATE SQL> select to_char(to_date('2004-12-17 16:42:42', 'syyyy-mm-dd hh24:mi:ss'), 'syyyy-mm-dd hh24:mi:ss') dat, DAT DUMP_DATE 存储在数据库中的DATE类型是12,而直接在SQL中使用的DATE类型是13。而且二者的长度以及表示方式都不相同。这两种类型的不同指出主要体现在两点:一:时、分、秒的表示不同;二、世纪和年的表示不同。 SQL中使用DATE的时分秒没有采用加1存储方式,而且原值存储。 SQL中使用DATE没有采用世纪、年的方式保持,而是采用了按数值保存的方式。第一位表示低位,第二位表示高位。低位表示最大的值是255。如上面的例子中,212+7×256=2004。 SQL> select to_char(to_date('-2004-12-17 16:42:42', 'syyyy-mm-dd hh24:mi:ss'), 'syyyy-mm-dd hh24:mi:ss') dat, DAT DUMP_DATE SQL> select dump(to_date('-1-1-1', 'syyyy-mm-dd')) from dual; DUMP(TO_DATE('-1-1-1','SYYYY-MM-D
对于公元前的日期,Oracle从255,255开始保存。公元前的年的保存的值和对应的公元后的年的值相加的和是256,255。如上例中的公元2004年和公元前2004年的值相加:212+44=256,7+248=255。 SQL中DATE类型最后还包括一个0,似乎目前没有使用。 |