Oracle针对不同的数据需求,提供了多种类、多层次的数据类型体系。我们在实际应用中,最好可以依据业务数据的实际形态和前端应用的语言、框架特性来确定字段类型的选择。

Date类型是我们经常使用的时间类型数据表示,包括了年月日时分秒信息。作为Date类型的一个拓展,Oracle提供了Timestamp数据类型,作为高精度时间类型的体现。

 

1、Timestamp的高精度

Timestamp在官方中的定义方式是timestamp(n),其中n表示秒级片段(fractional_seconds)的精确度。作为Date类型的一个拓展,Timestamp提供了更为精确的时间定位。

SQL> select systimestamp from dual;

SYSTIMESTAMP

--------------------------------------------------------------------------------

13-7月 -11 07.52.16.562000 下午 +08:00

SQL> select sysdate from dual;

SYSDATE

------------------------------

2011-7-13 20:13:55

使用systimestamp函数,我们可以获取到当前时间的timestamp with local time zone取值。默认情况下,我们发现和sysdate显示的有一些差异。控制和显示timestamp格式的参数,可以通过v$nls_parameters进行查看。

SQL> select * from v$nls_parameters;

PARAMETER                      VALUE

------------------------------ ----------------------------------------

(篇幅原因,有省略…)

NLS_SORT                       BINARY

NLS_TIME_FORMAT                HH.MI.SSXFF AM

NLS_TIMESTAMP_FORMAT           DD-MON-RR HH.MI.SSXFF AM

NLS_TIME_TZ_FORMAT             HH.MI.SSXFF AM TZR

NLS_TIMESTAMP_TZ_FORMAT        DD-MON-RR HH.MI.SSXFF AM TZR

19 rows selected

参数nls_timestamp_format和nls_timestamp_tz_format分别来控制timestamp和timestamp with local zone的显示格式。

上面systimestamp显示的信息,可以解析为:2011-7-13 19:52:16。稍稍费解的是秒后面的562000数字。这个是Timestamp的秒片段(fractional seconds),就是秒向下的精度划分。timestamp定义中的n就是指定的每秒划分的精度范围。

实际应用中,n取值为0-9,默认为6。从上面例子上的systimestamp函数返回值上看,也是的确如此。

SQL> create table t (d1 timestamp, d2 timestamp(0), d3 timestamp(9));

Table created

SQL> desc t;

Name Type         Nullable Default Comments

---- ------------ -------- ------- --------

D1   TIMESTAMP(6) Y

D2   TIMESTAMP(0) Y

D3   TIMESTAMP(9) Y

那么,timestamp类型的高精度有什么作用呢?个人认为大部分还是为了前端并发访问时候的锁机制,还有一些特殊行业的高精度需求。很多开发框架都需要使用一个高精度的数据列来标记行访问的时间顺序,通过timestamp的精度,基本可以满足这部分的需要。

 

2、Timestamp with time zone

Timestamp类型的另一个特性就是时区timezone特性。我们知道世界各地所处的时区不同,对应同一个时刻显示的时间是不同的。所以如果精确定义一个时间点,特别是对应一个全球性系统的时候,时区Timezone是不可或缺的考虑因素。

Date类型只能适应于一般时间的表示,如果加入了时区因素,就无能为力了。在这样的情况下,就可以选择Timestamp类型的一个拓展类型,timestamp with time zone。这样就可以把当前对应的时区信息加入到数据列中。

函数systimestamp返回标准类型就是timestamp with time zone。与一般timestamp类型不同的是,timestamp with time zone额外加入了当前时区的信息。

SQL> select systimestamp from dual;

SYSTIMESTAMP

--------------------------------------------------------------------------------

13-7月 -11 07.52.16.562000 下午 +08:00

+08:00表示时区,全球有12个时区。系统的时区通过参数设置或者当前操作系统OS的配置来获取。

SQL> create table t (d1 date, d2 timestamp, d3 timestamp with time zone);

Table created

SQL> insert into t values (systimestamp, systimestamp, systimestamp);

1 row inserted

SQL> commit;

Commit complete

SQL> select * from t;

D1                   D2                                       D3

-------------------- -----------

2011-7-13 21:12:32   13-7月 -11 09.12.32.859000 下午          13-7月 -11 09.12.32.859000 下午 +08:00

加入时区信息之后,可以做到全球时间下的绝对时间比较。

此外,timestamp还有一个timestamp with local time zone的拓展类型。也包括时区信息,与time zone的差别有下面几个:

ü        不管是什么时区的日期插入到数据库中,都会进行正规化工作。将其他时区的日期转化为数据库对应的时区(Database Time Zone)中;

ü        当进行检索操作的时候,local time zone类型数据又会被转化为当前检索会话对应的time zone中。这一系列的转化操作对end user而言都是透明的;

在对应会话和数据库的时区上,与系统参数NLS_TERRITORY是相关的。Oracle往往通过这个参数的国家设置来判断时区。而客户端的参数往往与nls_lang相关。

3、Timestamp显示格式控制

最后我们一起来看看timestamp显示的格式方式。默认情况下,timestamp以及timestamp with time zone的显示是与系统参数nls_timestamp_format和nls_timestamp_tz_format有关。在我们的实验环境下,两个格式字符串(format string)分别为:

NLS_TIMESTAMP_FORMAT           DD-MON-RR HH.MI.SSXFF AM

NLS_TIMESTAMP_TZ_FORMAT        DD-MON-RR HH.MI.SSXFF AM TZR

其中,DD、MON、HH和MI都是我们非常熟悉的日期格式字符串。RR表示使用年的后两位进行表示。而SSXFF是一个组合条件,应该被拆分为SS、X和FF三个部分。SS表示秒信息,X表示基数开关,而FF表示小于一秒的时间片段。

X表示的基数开关是什么意思呢?我们通过实验就可以看出情况。

SQL> select to_char(systimestamp,'DD-MON-RR HH.MI.SSXFF AM') SSXFF, to_char(systimestamp,'DD-MON-RR HH.MI.SSFF AM') SSFF from dual;

SSXFF                                  SSFF

-------------------------------------- -------------------------------------

13-7月 -11 09.37.16.843000 下午        13-7月 -11 09.37.16843000 下午

加入了X表示开关之后,就在秒为加入了一个.号表示分割。便于查看。

而AM表示是否使用(AM和PM)显示上下午信息,TZR则表示是否显示出时区信息。

当显示timestamp类型的时候,如果没有明确指定显示格式,系统会自动使用nls_timestamp_format系列参数。

SQL> select to_char(systimestamp, 'yyyy-mm-dd hh24:mi:ss ff tzr') from dual;

TO_CHAR(SYSTIMESTAMP,'YYYY-MM-

--------------------------------------------------------------

2011-07-13 21:40:50 265000 +08:00

如果期望在会话(或者系统)一级修改参数,就要使用alter session或者alter system方法。

SQL> select to_char(systimestamp) from dual;

TO_CHAR(SYSTIMESTAMP)

-----------------------------------------------------------------------

13-7月 -11 09.42.44.343000 下午 +08:00

//对当前会话修改参数;

SQL> alter session set nls_timestamp_tz_format='yyyy-mm-dd hh24:mi:ss ff tzr';

Session altered

SQL> select to_char(systimestamp) from dual;

TO_CHAR(SYSTIMESTAMP)

--------------------------------------------------------------

2011-07-13 21:43:18 984000 +08:00

4、结论

timestamp系列类型是对Oracle Date类型的一种有益补充。在需要的场合下,可以适当使用。

转载:http://blog.itpub.net/17203031/viewspace-702132

Timestamp类型浅析的更多相关文章

  1. mysql关于timestamp类型

    数据库设置时间字段为timestamp类型,DTO设置为java.util.Date类型.DTO设值sessionLogDTO.setLoginOutTime(new Date());用new Dat ...

  2. MySQL中DATETIME、DATE和TIMESTAMP类型的区别

    一.TIMESTAMP 显示格式:YYYY-MM-DD HH:MM:SS 时间范围:[ '1970-01-01 00:00:00'到'2037-12-31 23:59:59'] TIMESTAMP D ...

  3. java获取获得Timestamp类型的当前系统时间。以及java.util.date 、java.sql.Date之间的转换

    java获取取得Timestamp类型的当前系统时间java获取取得Timestamp类型的当前系统时间 格式:2010-11-04 16:19:42 方法1: Timestamp d = new T ...

  4. java 反射: 当Timestamp类型的属性值为null时,设置默认值

    import java.beans.PropertyDescriptor; import java.lang.reflect.Field; import java.lang.reflect.Metho ...

  5. java获取获得Timestamp类型的当前系统时间

    java获取取得Timestamp类型的当前系统时间java获取取得Timestamp类型的当前系统时间 格式:2010-11-04 16:19:42 方法1: Timestamp d = new T ...

  6. java获取获得Timestamp类型的当前系统时间。

    java获取获得Timestamp类型的当前系统时间.   java获取取得Timestamp类型的当前系统时间 格式:2010-11-04 16:19:42 方法1: Timestamp d = n ...

  7. 在hive中直接对timestamp类型取max报错

    之前直接对timestamp类型做max操作, select id,max(updatetime) updatetime from his.tag group by id; 结果查询的结果有的显示为1 ...

  8. EntityFrameworkCore将数据库Timestamp类型在程序中转为long类型

    EntityFrameworkCore将数据库Timestamp类型在程序中转为long类型 EntityFrameworkCore Entity public class Entity { publ ...

  9. TIMESTAMP类型字段在SQL Server和MySQL中的含义和使用

    公众号上转的满天飞的一篇文章,MySQL优化相关的,无意中瞄到一句“尽量使用TIMESTAMP而非DATETIME”,之前对TIMESTAMP也不太熟悉,很少使用,于是查了一下两者的区别. 其实,不管 ...

随机推荐

  1. [AirFlow]AirFlow使用指南三 第一个DAG示例

    经过前两篇文章的简单介绍之后,我们安装了自己的AirFlow以及简单了解了DAG的定义文件.现在我们要实现自己的一个DAG. 1. 启动Web服务器 使用如下命令启用: airflow webserv ...

  2. OpenGL实现相机视频NV21格式转RGB格式

    笔者介绍:姜雪伟,IT公司技术合伙人,IT高级讲师,CSDN社区专家,特邀编辑,畅销书作者,已出版书籍:<手把手教你架构3D游戏引擎>电子工业出版社和<Unity3D实战核心技术详解 ...

  3. PHP中 public、protected 和 privare的区别

    权限:public>protected>private public:谁都可以调用 protected:只有自己和派生类可以调用 privare:只有自己可以调用

  4. 如何去访问win8系统的共享文件夹

    关于共享,看过不少的贴子,觉得搞得很复杂.我看起来也很头痛.晕头转向的.其实我们作为家庭用户来说,不想搞得那么复杂,我们只要能做到能够从一台电脑访问另一台电脑的共享文件夹就可以了,这样我们就可以任意从 ...

  5. erlang游戏开发tcp

    之前在开发游戏的时候我们采用smartfoxserver这个java开发的游戏引擎,这个引擎在开发回合制游戏方面速度还是不错的.但是面对客户日益增长的需求还是有些力不从心.比如集群,比如灾备,热切换, ...

  6. C语言变量、函数的作用域及变量的存储方式

    一.变量的作用域和存储方式 在C语言中每个变量都有两种基本属性:数据类型.数据的存储类别. 数据类型很多人都已熟知,例如:字符型(char).整型(int).浮点型(float)等等.存储类别是指数据 ...

  7. java基础:eclipse编程不得不知道的技巧

    如果你是位具有开发经丰富的工程师,在开发的过程中,你就会很强烈的要求快捷的编程.如何快捷编程,只有更加熟悉开发工具.那么eclipse是同样也有很多技巧.可以带着下面问题来阅读1.如何查找类相关信息? ...

  8. andriod studio报错 Emulator: emulator: ERROR: x86 emulation currently requires hardware acceleration! Emulator: Process finished with exit code 1

    安装即可,再次运行svd,成功

  9. CentOS编译安装php7.2

    介绍: 久闻php7的速度以及性能那可是比php5系列的任何一版本都要快,具体性能有多好,建议还是先尝试下再说.如果你是升级或新安装,那你首先需要考虑php7和程序是否存在兼容性,如果程序是基于php ...

  10. grpc gateway 使用以及docker compose 集成

    1. grpc gateway 安装 参考,比较简单,有需要的依赖可以参考相资料 mkdir tmp cd tmp git clone https://github.com/google/protob ...