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

Wesley13
• 阅读 564
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);                    
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

 对比10

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);                    
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

从此处可以看到:

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就比较重要了。

结束

点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
2年前
MySQL Config
全局参数system\_time\_zone系统时区,在MySQL启动时会检查当前系统的时区并根据系统时区设置全局参数system\_time\_zone的值。Thesystemtimezone.Whentheserverstarts,itattemptstodeterminethetimezoneofthehos
Wesley13 Wesley13
2年前
mysql中时间比较的实现
MySql中时间比较的实现unix\_timestamp()unix\_timestamp函数可以接受一个参数,也可以不使用参数。它的返回值是一个无符号的整数。不使用参数,它返回自1970年1月1日0时0分0秒到现在所经过的秒数,如果使用参数,参数的类型为时间类型或者时间类型的字符串表示,则是从1970010100:00:0
Wesley13 Wesley13
2年前
oracle数值类型
Oracle固有数据类型DATE、TIMESTAMP和INTERVAL是紧密相关的。DATE和TIMESTAMP类型存储精度可变的固定日期/时间。INTERVAL类型可以很容易地存储一个时间量,如“8个小时”或“30天”。许多新应用都在使用TIMESTAMP类型,这有两个原因:一方面它支持小数秒,而DATE类型不支持;另一方面TIMESTAMP
Wesley13 Wesley13
2年前
MySQL中日期与时间类型
!(http://static.oschina.net/uploads/space/2014/0926/110202_V4dH_1582989.jpg)1、MySQL的五种日期和时间类型MySQl中有多种表示日期和时间的数据类型。其中YEAR表示年份,DATE表示日期,TIME表示时间,DATETIME和TIMESTAMP分别
Stella981 Stella981
2年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
mysql5.6 分页查询优化
mysql5.6分页查询优化场景:表结构:主键(非自增)contentCode(varchar),过滤条件列为updateTime(timeStamp),已经为timestamp建立索引。搜索sql为:SELECTFROMmy_hello_tableWHEREupdat
Wesley13 Wesley13
2年前
ORACLE常用系统查询SQL
1  查询系统所有对象SELECT OWNER, OBJECT_NAME, OBJECT_TYPE, CREATED, LAST_DDL_TIME, TIMESTAMP, STATUSFROM DBA_OBJECTS WHERE OWNERUPPER('SCOTT')2  查看系统所有表SELECT
Stella981 Stella981
2年前
Impala常用函数索引
增加X自然天selectdays_add(now(),2)字符串转Timestampselectto\_timestamp('2019101420:00:01','yyyyMMddHH:mm:ss');注意,Impala的timestamp的标准是ISO8601 参考:https://en.wiki
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_