ORACLE中,怎样获得两个时间相差的秒数?

 我来答
crystalstar0
高粉答主

2018-01-09 · 说的都是干货,快来关注
知道小有建树答主
回答量:190
采纳率:98%
帮助的人:6.1万
展开全部

ORACLE中获得两个时间相差的秒数有以下方法:

一、常规方法:

1、创建表

create table t_timestamp (id number, t1 timestamp, t2 timestamp);

2、插入数据

insert into t_timestamp 

values (1, to_timestamp('20120615233324', 'yyyymmddhh24miss'),

to_timestamp('20120619152354', 'yyyymmddhh24miss'));

二、通过EXTRACT函数获得对应的秒数:

将时间差求出来,然后通过EXTRACT函数对时间进行转换,获得对应的秒数。

1、第一种形式

sql>with t as (select t1 - t2 interval from t_timestamp where id = 1)

select extract(day from interval) * 86400+ extract(hour from interval) * 3600

+ extract(minute from interval) * 60+ extract(second from interval) interval from t;

2、第二种形式

sql>select extract(day from t1-t2) * 86400+ extract(hour from t1-t2) * 3600

+ extract(minute from t1-t2) * 60+ extract(second from t1-t2) interval from t_timestamp;

--889170

其他方法:

一、通过将时间转换为DATE方式,求出相应的秒数。

1、第一种形式

sql>select (t.t1-0-(t.t2-0))*86400 interval from  t_timestamp t

--889170

2、第二种形式

select (cast(t.t1 as date)-cast(t.t2 as date))*86400 interval from  t_timestamp t

二、如果是date时间格式,相对比较简单,可以直接通过时间差(天数)乘上84600即可。

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式