oracle如何在内部存储带时区的时间戳
基于Oracle文档,它在数字方面内部存储时区的不同部分和时区.我读了这篇文章 http://www.orafaq.com/wiki/Timestamp,它解释了时间戳内部格式的算法.所以我做了一个简单的测试来验证它. SQL> create table tz_test(id number,tz timestamp with time zone); Table created. SQL> insert into tz_test values(1,timestamp '1999-10-29 21:00:00 -7:00'); 1 row created. SQL> insert into tz_test values(2,timestamp '1999-10-29 21:00:00 US/Pacific'); 1 row created. SQL> select id,dump(tz,10) from tz_test where tz=timestamp '1999-10-29 21:00:00 -7:00'; ID DUMP(TZ,10) -------------------------------------------------------------------------------- 1 Typ=181 Len=13: 119,199,10,30,5,1,13,60 2 Typ=181 Len=13: 119,137,156 orafaq中的文章讨论了oracle如何存储时区偏移量,我的第一行测试证明了这一点.但是没有关于如何存储时区文字的信息.所以我很想知道它.我也想在内部了解oracle如何评估timestamp’1999-10-29 21:00:00 -7:00’和timestamp’1999-10-29 21:00:00 US / Pacific’是相同的. 解决方法它们似乎是来自 time zone file的区域ID,例如$ORACLE_HOME / oracore / zoneinfo区/ timezone_14.dat.In this SQL Fiddle,带时区PST8PDT的值最后两个字节为0x83,0x64;它与MOS文档ID 414590.1建议的值相匹配. 我看不到任何列出所有可能值的引用,或者检查时区文件的任何明显方法.它似乎没有记录,这对内部格式来说并不合理.您可以使用相同的方法找出您感兴趣的值或所有值,但我不确定您为什么要这样做. 还有另一个您可能会觉得有用的支持文档,340512.1,这是一个关于时间戳和时区的常见问题解答. 要将区域名称转换为偏移值,您可以使用the (编辑:PHP编程网 - 黄冈站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |