sc_1028 发表于 2013-1-13 19:03:08

DB2,日期和时间的使用

获得当前的日期、时间及时间戳记:
SELECT current date FROM sysibm.sysdummy1SELECT current time FROM sysibm.sysdummy1SELECT current timestamp FROM sysibm.sysdummy1
sysibm.sysdummy1表是一个特殊的内存中的表, 用它可以发现如上面演示的DB2寄存器的值. 您也可以使用关键字 VALUES 来对寄存器或表达式求值.以下 SQL 语句揭示了类似信息:
VALUES current dateVALUES current timeVALUES current timestamp
在余下的示例中,将只提供函数或表达式,而不再重复SELECT ... FROM sysibm.sysdummy1或使用VALUES子句.

给定了日期、时间或时间戳记, 则使用适当的函数可以单独抽取出(如果适用的话)年、月、日、时、分、秒及微秒各部分:
YEAR (current timestamp)MONTH (current timestamp)DAY (current timestamp)HOUR (current timestamp)MINUTE (current timestamp)SECOND (current timestamp)MICROSECOND (current timestamp)
从时间戳记单独抽取出日期和时间也非常简单:
DATE (current timestamp)TIME (current timestamp)
因为没有更好的术语,所以您还可以使用英语来执行日期和时间计算:
current date + 1 YEARcurrent date + 3 YEARS + 2 MONTHS + 15 DAYScurrent time + 5 HOURS - 3 MINUTES + 10 SECONDS
要计算两个日期之间的天数,您可以对日期作减法,如下所示:
days (current date) - days (date('1999-10-22'))
而以下示例描述了如何获得微秒部分归零的当前时间戳记:
CURRENT TIMESTAMP - MICROSECOND (current timestamp) MICROSECONDS
如果想将日期或时间值与其它文本相衔接,那么需要先将该值转换成字符串.为此,只要使用 CHAR() 函数:
char(current date)char(current time)char(current date + 12 hours)
要将字符串转换成日期或时间值,可以使用:
TIMESTAMP ('2002-10-20-12.00.00.000000')TIMESTAMP ('2002-10-20 12:00:00')DATE ('2002-10-20')DATE ('10/20/2002')TIME ('12:00:00')TIME ('12.00.00')
页: [1]
查看完整版本: DB2,日期和时间的使用