美文网首页
操作日期和时间

操作日期和时间

作者: lumicinta | 来源:发表于2017-01-25 19:40 被阅读0次

操作日期和时间

标签(空格分隔): SQL DB2


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

日期数据类型

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

类型 格式
TIME hh:mm:ss
DATE yyyy-mm-dd
TIMESTAMP yyyy-mm-dd hh:mm:ss.zzzzzz

日期时间运算:Case 1

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

    VALUES DATE('2009-10-1') + 1 DAY; 
    VALUES DATE('2009-10-1') + 5 DAYS; 

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

单数 复数
YEAR YEARS
MONTH MONTHS
DAY DAYS
HOUR HOURS
MINUTE MINUTES
SECOND SECONDS
MICROSECOND MICROSECONDS

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

VALUES DATE('2009-10-1') + 1 YEAR + 2 MONTH -8 DAY;
VALUES TIME('10:23:15') + 3 HOUR -26 MINUTE;  
VALUES TIMESTAMP('2009-10-1 10:23:15.000000') - 3 SECOND + 450 MICROSECOND;  

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

VALUES DATE('2009-10-1') + 2 HOUR; 
VALUES TIME('10:23:15') + 1 YEAR; 

日期时间运算:Case 2

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

--错误例子
VALUES DATE('2009-10-1') - DATE('2008-10-1');  
VALUES TIME('10:23:15') - TIME('10:22:15');  
VALUES TIMESTAMP('2009-10-1 10:23:15.000005') - TIMESTAMP('2009-10-1 10:22:15.000000');  

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

日期 DECIMAL 转换后的格式
DATE DECIMAL(8,0) yyyymmdd
TIME DECIMAL(6,0) hhmmss
TIMESTAMP DECIMAL(20,6) yyyymmdd hhmmss.zzzzzz

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

    20091001-20081001=10000;  
    102315-102215=100;  
    20091001102315.000005-20091001102215.000000=100.000005;  

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

DAYS

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

VALUES DAYS(DATE('2009-10-1') ) - DAYS(DATE('2008-10-1')) ;  
VALUES DAYS('2009-10-2' ) - DAYS('2009-10-1 10:40:15.000000') ;  
VALUES DAYS(TIMESTAMP('2009-10-2 10:23:15.000005'))  - DAYS(TIMESTAMP('2009-10-1 10:40:15.000000'));  

TIMESTAMPDIFF

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

TIMESTAMPDIFF (参数1,参数2)

参数1可以指定为:1、2、4、8、16、32、64、128、256,分别表示返回两个日期之间的毫秒数、秒数、分钟数、小时数、天数、周数、月数、季度数、年数

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

VALUES TIMESTAMPDIFF(1, CHAR(TIMESTAMP('2009-10-1 10:23:16.000000') -TIMESTAMP('2009-10-1 10:23:15.000000')));  
VALUES TIMESTAMPDIFF(2, CHAR(TIMESTAMP('2009-10-1 10:23:15.000000') -TIMESTAMP('2008-10-1 10:23:15.000000')));  
VALUES TIMESTAMPDIFF(4, CHAR(TIMESTAMP('2009-10-1 10:23:15.000000') -TIMESTAMP('2008-10-1 10:23:15.000000')));  
VALUES TIMESTAMPDIFF(8, CHAR(TIMESTAMP('2009-10-1 10:23:15.000000') -TIMESTAMP('2008-10-1 10:23:15.000000')));  
VALUES TIMESTAMPDIFF(16, CHAR(TIMESTAMP('2009-10-1 10:23:15.000000') -TIMESTAMP('2008-10-1 10:23:15.000000')));  
VALUES TIMESTAMPDIFF(32, CHAR(TIMESTAMP('2009-10-1 10:23:15.000000') -TIMESTAMP('2008-10-1 10:23:15.000000')));  
VALUES TIMESTAMPDIFF(64, CHAR(TIMESTAMP('2009-10-1 10:23:15.000000') -TIMESTAMP('2008-10-1 10:23:15.000000')));  
VALUES TIMESTAMPDIFF(128, CHAR(TIMESTAMP('2009-10-1 10:23:15.000000') -TIMESTAMP('2008-10-1 10:23:15.000000')));  
VALUES TIMESTAMPDIFF(256, CHAR(TIMESTAMP('2009-10-1 10:23:15.000000') -TIMESTAMP('2008-10-1 10:23:15.000000')));  

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

相关文章

  • 操作日期和时间

    操作日期和时间 标签(空格分隔): SQL DB2 我们都知道数字可以进行加、减、乘、除等运算。那么,日期时间可不...

  • 日期和时间

    日期和时间 必须 使用 Carbon 来处理日期和时间相关的操作。

  • Date、Error

    一、Date 什么是Date?封装日期和时间,提供操作日期和时间的API。何时使用日期对象?今后只要存储日期和时间...

  • Date对象

    1. 介绍:阐述 Date 对象。 Date对象,是操作日期和时间的对象。Date对象对日期和时间的操作只能通过方...

  • Python datetime函数常见用法总结

    Python datetime使用指导:操作时间、日期和时间区间 在 Python 中处理日期和时间是一个很麻烦的...

  • 【Python】中的时间和日期操作

    网易笔试中,因为没能将最后的结果(时间格式)打印出来,导致笔试失败,后悔莫及…… 模块: time 、calend...

  • C++---- 日期 & 时间

    C++ 标准库没有提供所谓的日期类型。C++ 继承了 C 语言用于日期和时间操作的结构和函数。为了使用日期和时间相...

  • C++<第二十篇>:日期与时间

    C++ 标准库没有提供所谓的日期类型。C++ 继承了 C 语言用于日期和时间操作的结构和函数。为了使用日期和时间相...

  • 各种时间函数的恩与怨

    C++标准库没有提供所谓的日期类型。C++继承了C语言用于日期和时间操作的结构和函数。为了使用日期和时间相关的函数...

  • java.util 包

    2.2 Date 类 Date 类表示日期和时间,里面封装了操作日期和时间的方法。Date 类经常用来获取系统当前...

网友评论

      本文标题:操作日期和时间

      本文链接:https://www.haomeiwen.com/subject/btxxittx.html