在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.