DB2日期时间的基础知识_DB2_数据库_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 数据库 > DB2 > DB2日期时间的基础知识

DB2日期时间的基础知识

 2013/8/9 17:21:00    程序员俱乐部  我要评论(0)
  • 摘要:DB2日期时间相关的处理方法是学习DB2数据库过程中必须要掌握的,下面就为您详细介绍DB2日期时间的基础知识,供您参考学习之用。为了用SQL语句得到当前的日期,时间和时间戳,可以使用相应的DB2寄存器:SELECTcurrentdateFROMsysibm.sysdummy1SELECTcurrenttimeFROMsysibm.sysdummy1SELECTcurrenttimestampFROMsysibm.sysdummy1sysibm.sysdummy1表是一个在内存中特殊的表
  • 标签:基础知识

DB2日期时间相关的处理方法是学习DB2数据库过程中必须要掌握的,下面就为您详细介绍DB2日期时间的基础知识,供您参考学习之用。

为了用SQL语句得到当前的日期,时间和时间戳,可以使用相应的DB2寄存器:

SELECT current date FROM sysibm.sysdummy1
SELECT current time FROM sysibm.sysdummy1
SELECT current timestamp FROM sysibm.sysdummy1

sysibm.sysdummy1表是一个在内存中特殊的表,可以使用上面的语句得到DB2寄存器的值。您也还可以用关键字VALUES来获取寄存器中的值。例如,在DB2命令行处理器中,可以用下面的SQL语句获取同样的信息:

VALUES current date
VALUES current time
VALUES current timestamp

在下面的示例中,我将只提供函数或表达式,而不再重复 SELECT ... FROM sysibm.sysdummy1 或使用VALUES子句。

要使当前时间或当前时间戳调整到格林威治标准时间(GMT/CUT),可以把当前的时间或时间戳减去当前时区寄存器:

current time - current timezone
current timestamp - current timezone

给定了日期、时间或时间戳,则使用适当的函数抽取出(如果适用的话)年、月、日、时、分、秒及微秒各部分:

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 YEAR
current date + 3 YEARS + 2 MONTHS + 15 DAYS
current 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')
 

发表评论
用户名: 匿名