0

我是 Vertica 的新手。

我正在尝试获取提供的秒数的日期时间。

我有 1980-01-01 的秒值。

当我这样尝试时:

\set interval '''1199283171.887953002212558175021 SECOND'''
SELECT DATE('1980-01-01') + INTERVAL :interval 

我得到我的输出:

2018-01-01 14:12:51.887953

(其中一个秒值设置为可变间隔。在 Linux putty 中尝试)

但我想将它用于表中的 100 条记录。这仅适用于单输入。我试过但没有得到它。

我怎样才能为所有值做到这一点?

4

1 回答 1

1

如果我没听错的话,你的浮点值是秒数的一百倍,这意味着自 '1980-01-01 00:00:00' 可能是 UTC 以来经过的秒数。

我找到了三种方法 - 正如您在此处看到的,使用 10 行示例表。

我只是懒惰并在您的初始秒值中添加了 << n >> 次 3600 秒。使其可读,因为结果时间戳的小时变化。如您所见,表达式都返回相同的值。

那会有帮助吗?

WITH input(secs) AS (
          SELECT 1199283171.887953002212558175021 + 0 * 3600
UNION ALL SELECT 1199283171.887953002212558175021 + 1 * 3600
UNION ALL SELECT 1199283171.887953002212558175021 + 2 * 3600
UNION ALL SELECT 1199283171.887953002212558175021 + 3 * 3600
UNION ALL SELECT 1199283171.887953002212558175021 + 4 * 3600
UNION ALL SELECT 1199283171.887953002212558175021 + 5 * 3600
UNION ALL SELECT 1199283171.887953002212558175021 + 6 * 3600
UNION ALL SELECT 1199283171.887953002212558175021 + 7 * 3600
UNION ALL SELECT 1199283171.887953002212558175021 + 8 * 3600
UNION ALL SELECT 1199283171.887953002212558175021 + 9 * 3600
)   
SELECT
  secs
, '1980-01-01'::TIMESTAMP + (secs::VARCHAR(32)||' SECOND')::INTERVAL     AS add_interval
, '1980-01-01'::TIMESTAMP + (secs/86400)                                 AS add_day_fraction
, TIMESTAMPADD(MICROSECOND,(1000000*secs)::INT, '1980-01-01'::TIMESTAMP) AS using_function
FROM input;
               secs               |        add_interval        |      add_day_fraction      |       using_function       
----------------------------------+----------------------------+----------------------------+----------------------------
 1199283171.887953002212558175021 | 2018-01-01 14:12:51.887953 | 2018-01-01 14:12:51.887953 | 2018-01-01 14:12:51.887953
 1199286771.887953002212558175021 | 2018-01-01 15:12:51.887953 | 2018-01-01 15:12:51.887953 | 2018-01-01 15:12:51.887953
 1199290371.887953002212558175021 | 2018-01-01 16:12:51.887953 | 2018-01-01 16:12:51.887953 | 2018-01-01 16:12:51.887953
 1199293971.887953002212558175021 | 2018-01-01 17:12:51.887953 | 2018-01-01 17:12:51.887953 | 2018-01-01 17:12:51.887953
 1199297571.887953002212558175021 | 2018-01-01 18:12:51.887953 | 2018-01-01 18:12:51.887953 | 2018-01-01 18:12:51.887953
 1199301171.887953002212558175021 | 2018-01-01 19:12:51.887953 | 2018-01-01 19:12:51.887953 | 2018-01-01 19:12:51.887953
 1199304771.887953002212558175021 | 2018-01-01 20:12:51.887953 | 2018-01-01 20:12:51.887953 | 2018-01-01 20:12:51.887953
 1199308371.887953002212558175021 | 2018-01-01 21:12:51.887953 | 2018-01-01 21:12:51.887953 | 2018-01-01 21:12:51.887953
 1199311971.887953002212558175021 | 2018-01-01 22:12:51.887953 | 2018-01-01 22:12:51.887953 | 2018-01-01 22:12:51.887953
 1199315571.887953002212558175021 | 2018-01-01 23:12:51.887953 | 2018-01-01 23:12:51.887953 | 2018-01-01 23:12:51.887953
于 2018-06-14T15:33:29.773 回答