真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Oracle基本數(shù)據(jù)類型存儲(chǔ)格式淺析——日期類型TIMESTAMPWITHTIMEZONE

原文鏈接: https://www.modb.pro/db/22143?cyn 

創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比呼蘭網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式呼蘭網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋呼蘭地區(qū)。費(fèi)用合理售后完善,10年實(shí)體公司更值得信賴。

摘要:描述TIMESTAMP WITH TIME ZONE以及TIMESTAMP WITH LOCAL TIME ZONE類型的存儲(chǔ)結(jié)構(gòu)

本文對(duì)TIMESTAMP WITH LOCAL TIME ZONE和TIMESTAMP WITH TIME ZONE類型的存儲(chǔ)格式進(jìn)行簡(jiǎn)單的說(shuō)明。

SQL> CREATE TABLE TEST_TIMESTAMP(TIME1 TIMESTAMP(9), TIME2 TIMESTAMP(6) WITH LOCAL TIME ZONE, 
  2  TIME3 TIMESTAMP(4) WITH TIME ZONE);
表已創(chuàng)建。
SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);
已創(chuàng)建 1 行。
SQL> SELECT * FROM TEST_TIMESTAMP;
TIME1
----------------------------------------------------
TIME2
----------------------------------------------------
TIME3
----------------------------------------------------
11-1月 -05 11.08.15.027000000 下午
11-1月 -05 11.08.15.027000 下午
11-1月 -05 11.08.15.0270 下午 +08:00
SQL> SELECT DUMP(TIME1, 16), DUMP(TIME2, 16), DUMP(TIME3, 16) FROM TEST_TIMESTAMP;
DUMP(TIME1,16)
-------------------------------------------------------------
DUMP(TIME2,16)
-------------------------------------------------------------
DUMP(TIME3,16)
-------------------------------------------------------------
Typ=180 Len=11: 78,69,1,b,18,9,10,1,9b,fc,c0
Typ=231 Len=11: 78,69,1,b,18,9,10,1,9b,fc,c0
Typ=181 Len=13: 78,69,1,b,10,9,10,1,9b,fc,c0,1c,3c

可以發(fā)現(xiàn),如果客戶端和數(shù)據(jù)庫(kù)中的時(shí)區(qū)是一致的,那么TIMESTAMP和TIMESTAMP WITH LOCAL TIME ZONE存儲(chǔ)的數(shù)據(jù)是完全一樣的。
TIMESTAMP WITH TIME ZONE則略有不同,它保存的是0時(shí)區(qū)的時(shí)間,和所處的時(shí)區(qū)信息。
修改客戶端主機(jī)的時(shí)區(qū),由東8區(qū)(+8區(qū))改為0時(shí)區(qū)。

SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);
已創(chuàng)建 1 行。

修改客戶端主機(jī)的時(shí)區(qū),改為西5區(qū)(-5時(shí)區(qū))。

SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);
已創(chuàng)建 1 行。

修改客戶端主機(jī)的時(shí)區(qū),改為西12區(qū)(-12時(shí)區(qū))。

SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);
已創(chuàng)建 1 行。

修改客戶端主機(jī)的時(shí)區(qū),改為東13區(qū)(+13時(shí)區(qū))。

SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);
已創(chuàng)建 1 行。

修改客戶端主機(jī)的時(shí)區(qū),改為西3.5區(qū)(-3.5時(shí)區(qū))。

SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);
已創(chuàng)建 1 行。

修改客戶端主機(jī)的時(shí)區(qū),改為東9.5區(qū)(+9.5時(shí)區(qū))。

SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);
已創(chuàng)建 1 行。
SQL> COMMIT;
提交完成。

修改客戶端主機(jī)的時(shí)區(qū),改回東8區(qū)(+8時(shí)區(qū))。

SQL> SELECT * FROM TEST_TIMESTAMP;
TIME1
-----------------------------------------------
TIME2
-----------------------------------------------
TIME3
-----------------------------------------------
11-1月 -05 11.08.15.027000000 下午
11-1月 -05 11.08.15.027000 下午
11-1月 -05 11.08.15.0270 下午 +08:00
11-1月 -05 03.11.43.746000000 下午
11-1月 -05 11.11.43.746000 下午
11-1月 -05 03.11.43.7460 下午 +00:00
11-1月 -05 10.14.08.987000000 上午
11-1月 -05 11.14.08.987000 下午
11-1月 -05 10.14.08.9870 上午 -05:00
11-1月 -05 03.15.01.732000000 上午
11-1月 -05 11.15.01.732000 下午
11-1月 -05 03.15.01.7320 上午 -12:00
12-1月 -05 04.20.21.522000000 上午
11-1月 -05 11.20.21.522000 下午
12-1月 -05 04.20.21.5220 上午 +13:00
11-1月 -05 02.15.16.567000000 下午
12-1月 -05 01.45.16.567000 上午
11-1月 -05 02.15.16.5670 下午 -03:30
12-1月 -05 03.16.54.992000000 上午
12-1月 -05 01.46.54.992000 上午
12-1月 -05 03.16.54.9920 上午 +09:30
已選擇7行。
SQL> SELECT DUMP(TIME1, 16), DUMP(TIME2, 16), DUMP(TIME3, 16) FROM TEST_TIMESTAMP;
DUMP(TIME1,16)
-------------------------------------------------------------
DUMP(TIME2,16)
-------------------------------------------------------------
DUMP(TIME3,16)
-------------------------------------------------------------
Typ=180 Len=11: 78,69,1,b,18,9,10,1,9b,fc,c0
Typ=231 Len=11: 78,69,1,b,18,9,10,1,9b,fc,c0
Typ=181 Len=13: 78,69,1,b,10,9,10,1,9b,fc,c0,1c,3c
Typ=180 Len=11: 78,69,1,b,10,c,2c,2c,77,e,80
Typ=231 Len=11: 78,69,1,b,18,c,2c,2c,77,e,80
Typ=181 Len=13: 78,69,1,b,10,c,2c,2c,77,e,80,14,3c
Typ=180 Len=11: 78,69,1,b,b,f,9,3a,d4,6c,c0
Typ=231 Len=11: 78,69,1,b,18,f,9,3a,d4,6c,c0
Typ=181 Len=13: 78,69,1,b,10,f,9,3a,d4,6c,c0,f,3c
Typ=180 Len=11: 78,69,1,b,4,10,2,2b,a1,6f,0
Typ=231 Len=11: 78,69,1,b,18,10,2,2b,a1,6f,0
Typ=181 Len=13: 78,69,1,b,10,10,2,2b,a1,6f,0,8,3c
Typ=180 Len=11: 78,69,1,c,5,15,16,1f,1d,16,80
Typ=231 Len=11: 78,69,1,b,18,15,16,1f,1d,16,80
Typ=181 Len=13: 78,69,1,b,10,15,16,1f,1d,16,80,21,3c
Typ=180 Len=11: 78,69,1,b,f,10,11,21,cb,bb,c0
Typ=231 Len=11: 78,69,1,c,2,2e,11,21,cb,bb,c0
Typ=181 Len=13: 78,69,1,b,12,2e,11,21,cb,bb,c0,11,1e
Typ=180 Len=11: 78,69,1,c,4,11,37,3b,20,b8,0
Typ=231 Len=11: 78,69,1,c,2,2f,37,3b,20,b8,0
Typ=181 Len=13: 78,69,1,b,12,2f,37,3b,20,b8,0,1d,5a
 
SQL> SELECT TO_NUMBER('1C', 'XXX'), TO_NUMBER('3C', 'XXX') FROM DUAL;
TO_NUMBER('1C','XXX') TO_NUMBER('3C','XXX')
--------------------- ---------------------
                   28                    60
SQL> SELECT TO_NUMBER('14', 'XXX'), TO_NUMBER('3C', 'XXX'), TO_NUMBER('143C', 'XXXXXXX') FROM DUAL;
TO_NUMBER('14','XXX') TO_NUMBER('3C','XXX')
--------------------- ---------------------
                   20                    60
SQL> SELECT TO_NUMBER('3C', 'XXX') , TO_NUMBER('1E', 'XXX'), TO_NUMBER('5A', 'XXX') FROM DUAL;
TO_NUMBER('3C','XXX') TO_NUMBER('1E','XXX') TO_NUMBER('5A','XXX')
--------------------- --------------------- ---------------------
                   60                    30                    90

可以看出,修改時(shí)區(qū)會(huì)導(dǎo)致系統(tǒng)TIMESTAMP時(shí)間發(fā)生變化,但是對(duì)于TIMESTAMP WITH LOCAL TIME ZONE類型,總是將系統(tǒng)的時(shí)間轉(zhuǎn)化到數(shù)據(jù)庫(kù)服務(wù)器上時(shí)區(qū)的時(shí)間進(jìn)行存儲(chǔ)。
TIMESTAMP WITH TIME ZONE保存的是當(dāng)前時(shí)間轉(zhuǎn)化到0時(shí)區(qū)的對(duì)應(yīng)的時(shí)間,并通過(guò)最后兩位來(lái)保存時(shí)區(qū)信息。
第一位表示時(shí)區(qū)的小時(shí)部分。0時(shí)區(qū)用0x14表示。東n區(qū)在這個(gè)基礎(chǔ)上加n,西n區(qū)在這個(gè)基礎(chǔ)上減n。我們所處的東8區(qū)表示為0x1C。西5區(qū)表示為0xF。
第二位表示時(shí)區(qū)的分鐘部分。標(biāo)準(zhǔn)是0x3C,即60分鐘。對(duì)于東時(shí)區(qū)的半?yún)^(qū),在這個(gè)基礎(chǔ)上加上30分鐘,如果是西時(shí)區(qū),則減去30分鐘。

更多Oracle經(jīng)典案例解析: https://www.modb.pro/u/379?cyn 


新聞名稱:Oracle基本數(shù)據(jù)類型存儲(chǔ)格式淺析——日期類型TIMESTAMPWITHTIMEZONE
標(biāo)題網(wǎng)址:http://weahome.cn/article/pdihdg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部