现在的位置: 首页 > 综合 > 正文

操作日期和时间

2013年06月03日 ⁄ 综合 ⁄ 共 2808字 ⁄ 字号 评论关闭

----start

 我们都知道数字可以进行加、减、乘、除等运算。那么,日期可不可以呢?答案是,日期只能进行加、减运算。

 

在开始操作日期之前,我们得先了解DB2 支持哪些日期数据类型,如下所示:

 

类型

格式

TIME

hh:mm:ss

DATE

yyyy-mm-dd

TIMESTAMP

yyyy-mm-dd hh:mm:ss.zzzzzz

 

下面,我们还是先看一个简单的例子吧,如下所示:

 

如上所示,我们可以以人类英语的方式来操作日期,那么,除了DAYDAYS之外,DB2还支持哪些关键字呢?如下所示:

单数

复数

YEAR

YEARS

MONTH

MONTHS

DAY

DAYS

HOUR

HOURS

MINUTE

MINUTES

SECOND

SECONDS

MICROSECOND

MICROSECONDS

 

  单数和复数关键字在使用上没有任何区别,之所以分单数和复数,可能是考虑英语的语言习惯。下面是一些简单的例子:

 

  怎么样?使用起来是不是非常简单。不过,还有个问题我们需要思考,如果给DATE类型日期加上2小时,或者给TIME类型的日期加上1会出现怎样的情况呢?请读者自己运行下面的代码找答案吧。

 

  有时候,我们需要知道两个日期之间相隔多少天,也就是说求日期之间的时间间隔,该怎么办呢?我们很自然的想到把两个日期相减,如下所示:

 

运行上面的语句后,你可能感觉很失望,答案并不是我们期望的结果。上面的语句,首先将日期类型转换为DECIMAL类型,然后进行减法运算。转换规则如下:

 

 

日期

DECIMAL

转换后的格式

DATE

DECIMAL(8,0)

yyyymmdd

TIME

DECIMAL(6,0)

hhmmss

TIMESTAMP

DECIMAL(20,6)

yyyymmddhhmmss.zzzzzz

 

所以,上面的三条语句的结果如下:

 

那么,到底该怎样求时间间隔呢?下面给大家介绍两个函数:DAYS
TIMESTAMPDIFF

 

DAYS 函数可以用来求两个日期的天数,如下SQL所示:

 

DAYS 函数只能用来求两个日期之间天数,不够灵活。更灵活的是TIMESTAMPDIFF函数,TIMESTAMPDIFF函数的定义如下:

 

TIMESTAMPDIFF (参数1,参数2)

 

参数1可以指定为:1248163264128256,分别表示返回两个日期之间的毫秒数、秒数、分钟数、小时数、天数、周数、月数、季度数、年数。

 

参数2是两个日期相减的结果,如下SQL所示:

 

有关日期的操作还有很多,请参考日期时间函数。

---更多参见:DB2 SQL 精萃

----声明:转载请注明出处。

----last updated on 2009.10.29

----written by ShangBo on 2009.9.29

----end

 

抱歉!评论已关闭.