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.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数据源的港湾

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值