Trafodion 使用DATEDIFF计算两个时间差

在Trafodion中,我们使用DATEDIFF内嵌函数来计算两个时间差值,计算的时间差可以包括多种粒度,如YEAR、MONTH、DAY、HOUR、MINUTE、SECOND、QUARTER、WEEK。

DATEDIFF的用法如下,

DATEDIFF (datepart, startdate, enddate)

其中,以上datepart即上述YEAR、MONTH、DAY等这些不同的粒度,startdate和endate分别表示开始时间和结束时间,类型可以是date类型也可以是timestamp类型。DATEDIFF的详细语法请参考Apache Trafodion官网地址: http://trafodion.apache.org/docs/sql_reference/index.html#datediff_function

下面我们列举几个常用的计算两个时间差的例子,

1 计算两个日期差距多少天

SQL>select datediff(DAY,date '2017-12-05', date '2018-03-07') from dual;

(EXPR)
-----------
         92

--- 1 row(s) selected.

当然,这种场景我们也可以直接将两个日期相减得到结果,如下

SQL>select  date '2018-03-07' - date '2017-12-05' from dual;

(EXPR)
-------------
          92 

--- 1 row(s) selected.

2 计算两个时间戳差距多少天

SQL>select datediff(DAY,timestamp '2017-12-05 10:20:30', timestamp '2018-03-07 09:10:20') from dual;

(EXPR)
-----------
         92

--- 1 row(s) selected.

对于此场景,我们无法直接将两个时间戳相减得到结果,因为默认情况下,两个时间戳相关的粒度是SECOND(秒)。

SQL>select timestamp '2018-03-07 09:10:20' - timestamp '2017-12-05 10:20:30' from dual;

(EXPR)
-------------
     7944590 

3 计算两个日期差距多少个月

SQL>select datediff(MONTH,date '2017-12-05', date '2018-03-07') from dual;

(EXPR)
-----------
          3

--- 1 row(s) selected.

4 计算两个时间戳差距多少秒

SQL>select datediff(SECOND,timestamp '2017-12-05 10:20:30', timestamp '2018-03-07 09:10:20') from dual;

(EXPR)
-----------
    7944590

--- 1 row(s) selected.

注:
如果startdate和enddate是YYYY-MM-DD格式的字符串,DATEDIFF也是可以正常运行的,因为YYYY-MM-DD格式字符串可以隐式转换为日期类型。

SQL>select datediff(DAY, '2017-12-05', '2018-03-07') from dual;

(EXPR)
-----------
         92

--- 1 row(s) selected.

你可能感兴趣的:(Trafodion 使用DATEDIFF计算两个时间差)