Oracle基本資料型別儲存格式淺析(三)——日期型別(三)
Oracle基本資料型別儲存格式淺析(三)——日期型別(三)
如果直接在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
SQL> select to_char(date_col, 'syyyy-mm-dd hh24:mi:ss') dat, dump(date_col) dump_date from test_date;
DAT DUMP_DATE
-------------------- ---------------------------------------------------------
2004-12-17 16:42:42 Typ=12 Len=7: 120,104,12,17,17,43,43
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,
2 dump(to_date('2004-12-17 16:42:42', 'syyyy-mm-dd hh24:mi:ss')) dump_date from dual;
DAT DUMP_DATE
-------------------- ---------------------------------------------------------
2004-12-17 16:42:42 Typ=13 Len=8: 212,7,12,17,16,42,42,0
儲存在資料庫中的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,
2 dump(to_date('-2004-12-17 16:42:42', 'syyyy-mm-dd hh24:mi:ss')) dump_date from dual;
DAT DUMP_DATE
-------------------- ---------------------------------------------------
-2004-12-17 16:42:42 Typ=13 Len=8: 44,248,12,17,16,42,42,0
SQL> select dump(to_date('-1-1-1', 'syyyy-mm-dd')) from dual;
DUMP(TO_DATE('-1-1-1','SYYYY-MM-D
---------------------------------
Typ=13 Len=8: 255,255,1,1,0,0,0,0
對於公元前的日期,Oracle從255,255開始儲存。公元前的年的儲存的值和對應的公元后的年的值相加的和是256,255。如上例中的公元2004年和公元前2004年的值相加:212+44=256,7+248=255。
SQL中DATE型別最後還包括一個0,似乎目前沒有使用。
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
SQL> select to_char(date_col, 'syyyy-mm-dd hh24:mi:ss') dat, dump(date_col) dump_date from test_date;
DAT DUMP_DATE
-------------------- ---------------------------------------------------------
2004-12-17 16:42:42 Typ=12 Len=7: 120,104,12,17,17,43,43
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,
2 dump(to_date('2004-12-17 16:42:42', 'syyyy-mm-dd hh24:mi:ss')) dump_date from dual;
DAT DUMP_DATE
-------------------- ---------------------------------------------------------
2004-12-17 16:42:42 Typ=13 Len=8: 212,7,12,17,16,42,42,0
儲存在資料庫中的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,
2 dump(to_date('-2004-12-17 16:42:42', 'syyyy-mm-dd hh24:mi:ss')) dump_date from dual;
DAT DUMP_DATE
-------------------- ---------------------------------------------------
-2004-12-17 16:42:42 Typ=13 Len=8: 44,248,12,17,16,42,42,0
SQL> select dump(to_date('-1-1-1', 'syyyy-mm-dd')) from dual;
DUMP(TO_DATE('-1-1-1','SYYYY-MM-D
---------------------------------
Typ=13 Len=8: 255,255,1,1,0,0,0,0
對於公元前的日期,Oracle從255,255開始儲存。公元前的年的儲存的值和對應的公元后的年的值相加的和是256,255。如上例中的公元2004年和公元前2004年的值相加:212+44=256,7+248=255。
SQL中DATE型別最後還包括一個0,似乎目前沒有使用。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12801008/viewspace-607643/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle基本資料型別儲存格式淺析(三)——日期型別(一)Oracle資料型別
- Oracle基本資料型別儲存格式淺析(三)——日期型別(二)Oracle資料型別
- Oracle基本資料型別儲存格式淺析(三)——日期型別(四)Oracle資料型別
- Oracle基本資料型別儲存格式淺析——RAW型別Oracle資料型別
- Oracle基本資料型別儲存格式淺析(五)——RAW型別Oracle資料型別
- Oracle基本資料型別儲存格式淺析[zt]Oracle資料型別
- Oracle基本資料型別儲存格式淺析(四)——ROWID型別Oracle資料型別
- Oracle基本資料型別儲存格式淺析(二)——數字型別Oracle資料型別
- Oracle Lob型別儲存淺析Oracle型別
- 三,基本資料型別(下)資料型別
- (三)Python基本資料型別Python資料型別
- Oracle Xmltype型別淺析OracleXML型別
- Oracle 儲存型別Oracle型別
- oracle資料型別與儲存結構Oracle資料型別
- MYSQL 資料型別儲存-數值型MySQL 資料型別
- mysql儲存日期使用什麼型別MySql型別
- ORACLE日期型別Oracle型別
- 基本資料型別與字串型別資料型別字串
- rust學習三、基本型別Rust型別
- js資料型別之基本資料型別和引用資料型別JS資料型別
- oracle 各資料型別dump說明(三)Oracle資料型別
- 三、資料型別初識資料型別
- JavaScript中的資料型別-儲存差別JavaScript資料型別
- 基本資料型別資料型別
- double型別資料在記憶體中中儲存格式型別記憶體
- Timestamp型別淺析型別
- redis-4.資料儲存型別Redis型別
- MYSQL-資料型別儲存-DATEMySql資料型別
- ORACLE 9I 中的日期格式型別Oracle型別
- Redis(一):基本資料型別與底層儲存結構Redis資料型別
- Oracle三種集合資料型別的比較Oracle資料型別
- 【MySQL資料型別2之--日期時間型別】MySql資料型別
- Redis 三種特殊資料型別Redis資料型別
- JAVA中基本資料型別和引用資料型別Java資料型別
- 【MySQL】時間型別儲存格式選擇MySql型別
- Mysql資料庫學習(二):資料型別(數值型別 日期和時間型別 字串型別)MySql資料庫資料型別字串
- [譯] Scala 型別的型別(三)型別
- 淺談oracle複合資料型別Oracle資料型別