在Firebird中创建一个整数时间戳

时间:2015-01-08 16:01:22

标签: sql casting timestamp firebird epoch

我需要一个时间戳作为整数(请不要问我为什么,我完全被这个困扰)。定义是1970年1月1日之后的秒数。

我的初始值是一个格式为

的字符串

YYYYMMDDHHMMSS(例如20140108154821)

我已经能够建立一个正常的时间戳

CAST(
(SUBSTRING ( t.thetime FROM 5 FOR 2 )||'/'||SUBSTRING ( t.thetime FROM 7 FOR 2 )||'/'||SUBSTRING ( t.thetime FROM 1 FOR 4 )||' ' ||SUBSTRING ( t.thetime FROM 9 FOR 2 )||':'||SUBSTRING ( t.thetime FROM 11 FOR 2 )||':'||SUBSTRING ( t.thetime FROM 13 FOR 2 )||'.00'
) AS TIMESTAMP)

然后我尝试使用这种技术将其转换为int

CAST(cast(
(SUBSTRING ( t.thetime FROM 5 FOR 2 )||'/'||SUBSTRING ( t.thetime FROM 7 FOR 2 )||'/'||SUBSTRING ( t.thetime FROM 1 FOR 4 )||' '|| SUBSTRING ( t.thetime FROM 9 FOR 2 )||':'||SUBSTRING ( t.thetime FROM 11 FOR 2 )||':'||SUBSTRING ( t.thetime FROM 13 FOR 2 )||'.00'
) AS TIMESTAMP)
-cast('01/01/1970 00:00:00' as timestamp) as BIGINT) as TIMESTAMP_INT

我得到一个整数,但看起来好像返回的值是天数等等。

e.g。 08.01.2015,16:33:01.114成为16444

为什么会发生这种情况或者有其他方法可以做出任何建议?

我正在使用Firebird版本2.5

提前致谢

PS:

SELECT 
CAST(cast(
    (SUBSTRING ( '20140108154821' FROM 5 FOR 2 )||'/'||SUBSTRING ( '20140108154821' FROM 7 FOR 2 )||'/'||SUBSTRING ( '20140108154821' FROM 1 FOR 4 )||' '
    ||
    SUBSTRING ( '20140108154821' FROM 9 FOR 2 )||':'||SUBSTRING ( '20140108154821' FROM 11 FOR 2 )||':'||SUBSTRING ( '20140108154821' FROM 13 FOR 2 )||'.00'
    ) AS TIMESTAMP)
    -cast('01/01/1970 00:00:00' as timestamp) as BIGINT) 
    from sometable

;

2 个答案:

答案 0 :(得分:3)

执行此操作的一种方法是使用DATEDIFF

SELECT DATEDIFF(second, TIMESTAMP'1970-01-01 00:00', CURRENT_TIMESTAMP) 
FROM RDB$DATABASE

这假定时间是UTC,否则您可能需要通过时区偏移来补偿(例如,对于CET(UTC + 1),您使用TIMESTAMP'1970-01-01 01:00'代替)。

答案 1 :(得分:1)

是的,当您减去两个时间戳时,答案就是它们之间的天数。所以你想要做的是从时间戳中减去“大爆炸”的时间戳,然后乘以一天中的秒数,即

SELECT floor((yourTIMESTAMP - cast('1970-01-01' as TIMESTAMP)) * 86400)
FROM rdb$database

yourTIMESTAMP替换为将字符串转换为时间戳的代码,常量86400是每天的秒数。