Oracle中的 timestamp 和 timestamp with time zone, timestamp with local time zone

时区与Timestamp详解

开始

从网络学习文章:http://blog.youkuaiyun.com/zhangmenghao1983/article/details/5185591

我自己的实验:

复制代码
SQL> select dbtimezone, sessiontimezone from dual;                    
                    
DBTIME                    
------                    
SESSIONTIMEZONE                    
---------------------------------------------------------------------------                    
+00:00                    
-08:00                    
                    
                    
SQL>                     
                    
                    
                    
SQL> create table timetest(tme date,tmestp timestamp(3), tmestp_tz timestamp(3) with time zone, tmpstp_tzl timestamp(3) with local time zone);                    
                    
Table created.                    
                    
SQL>                     
                    
                    
                    
SQL> insert into timetest values(sysdate,sysdate,sysdate,sysdate);                    
                    
1 row created.                    
                    
SQL> select * from timetest;                    
                    
TME                    
---------                    
TMESTP                    
---------------------------------------------------------------------------                    
TMESTP_TZ                    
---------------------------------------------------------------------------                    
TMPSTP_TZL                    
---------------------------------------------------------------------------                    
11-Nov-12                    
11-NOV-12 11.56.27.000 PM                    
11-NOV-12 11.56.27.000 PM -08:00                    
11-NOV-12 11.56.27.000 PM                    
复制代码

对比:

复制代码
SQL> alter session set time_zone='+10:00';

Session altered.

SQL> select * from timetest;

TME
---------
TMESTP
---------------------------------------------------------------------------
TMESTP_TZ
---------------------------------------------------------------------------
TMPSTP_TZL
---------------------------------------------------------------------------
11-Nov-12
11-NOV-12 11.56.27.000 PM
11-NOV-12 11.56.27.000 PM -08:00
12-NOV-12 05.56.27.000 PM
复制代码

从此处可以看到:

timestamp with time zone 表达的是 针对 标准时区(格林尼治时间)的差。

timestamp with local time zone 表达的是 ,根据你当前所处时区,变化你和格林尼治时间的差。

如果过去相对标准时区 -8 ,那么移动到+10 时区的时候,需要加:10-(-8)=18 ,

就是 夜里11点56分+18小时 -->夜11点+1点+17小时+56分,-->凌晨过17小时+56分 -->凌晨+12小时+5小时+56分,

就是下午5小时56分。

那么,在跨越多时区的系统里,timestamp with timezone 或者 timestamp with local timezone就比较重要了。

结束





本文转自健哥的数据花园博客园博客,原文链接:http://www.cnblogs.com/gaojian/archive/2012/11/12/2766526.html,如需转载请自行联系原作者

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值