zoukankan      html  css  js  c++  java
  • Oracle底子根基数据圭臬尺度存储格式浅析(三)——日期圭臬尺度(四)

     来源:yangtingkun.itpub.net




    本文对TIMESTAMP WITH LOCAL TIME ZONE和TIMESTAMP WITH TIME ZONE圭臬尺度的存储格式住手复杂的阐明');。

     


    SQL> CREATE TABLE TEST_TIMESTAMP(TIME1 TIMESTAMP(9), TIME2 TIMESTAMP(6) WITH LOCAL TIME ZONE,
      2  TIME3 TIMESTAMP(4) WITH TIME ZONE);

    表已创设。

    SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);

    已创设 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

    可以发明,若是客户端和数据库中的时区是分例如的,那么TIMESTAMP和TIMESTAMP WITH LOCAL TIME ZONE存储的数据是完全一样的。

    TIMESTAMP WITH TIME ZONE则略有差别,它保留的是0时区的时候,和所处的时区信息。

    修改客户端主机的时区,由东8区( 8区)改为0时区。

    SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);

    已创设 1 行。

    修改客户端主机的时区,改为西5区(-5时区)。

    SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);

    已创设 1 行。

    修改客户端主机的时区,改为西12区(-12时区)。

    SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);

    已创设 1 行。

    修改客户端主机的时区,改为东13区( 13时区)。

    SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);

    已创设 1 行。

    修改客户端主机的时区,改为西3.5区(-3.5时区)。

    SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);

    已创设 1 行。

    修改客户端主机的时区,改为东9.5区( 9.5时区)。

    SQL> INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP, SYSTIMESTAMP, SYSTIMESTAMP);

    已创设 1 行。


    SQL> COMMIT;

    提交完成。

    修改客户端主机的时区,改回东8区( 8时区)。

    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

    可以看出,修改时区会招致系统TIMESTAMP时候孕育发生变化,可是关于TIMESTAMP WITH LOCAL TIME ZONE圭臬尺度,老是将系统的时候转化到数据库效能器上时区的时候住手存储。

    TIMESTAMP WITH TIME ZONE保留的是从此时候转化到0时区的对应的时候,并议决最初两位来保留时区信息。

    第一位泄漏表示时区的小时部门。0时区用0x14泄漏表示。东n区在这个底子根基上加n,西n区在这个底子根基上减n。我们所处的东8区泄漏表示为0x1C。西5区泄漏表示为0xF。

    第二位泄漏表示时区的分钟部门。尺度是0x3C,即60分钟。关于东时区的半区,在这个底子根基上加上30分钟,若是是西时区,则减去30分钟。




    版权声明: 原创作品,许可转载,转载时请务必以超链接方法标明文章 原始来由 、作者信息和本声明。否则将追查司法责任。

  • 相关阅读:
    浅谈管道模型(Pipeline)
    经常使用的webservice接口
    2012年终总结
    【Linux】linux经常使用基本命令
    php:兄弟连之面向对象版图形计算器1
    学习selenium所须要具备的技术
    Sftp和ftp 差别、工作原理等(汇总ing)
    对数据分布进行可视化的方法
    FusionCharts简单教程(一)---建立第一个FusionCharts图形
    闭包和柯里化
  • 原文地址:https://www.cnblogs.com/zgqjymx/p/1976115.html
Copyright © 2011-2022 走看看