Подтвердить что ты не робот

PostgreSQL: добавить интервал к отметке времени из значения столбца

Мне нужно добавить минуты, исходящие из целочисленного столбца с меткой времени, чтобы сравнить с другим столбцом.

Вот пример:

 SELECT t1.id_liame, t1.id_table, t1.periodicidade , t3.data_extracao, 
    CASE WHEN(NOW() < (e.data_extracao + INTERVAL t1.periodicidade || '
    MINUTES')) 
    THEN 'yes' ELSE 'no' END
    FROM table1 as t1 LEFT JOIN liame_has_extracao as t2 USING(id_liame)
    LEFT JOIN extracao as t3 USING(id_extracao)

l.periodicidade - целое число (минуты)
Мне нужно проверить, если data_extracao(timestamp) больше, чем NOW() + l.periodicidade(integer - minutes).

Как я могу это сделать?

4b9b3361

Ответ 1

Вы можете написать свой запрос следующим образом:

SELECT 
   t1.id_liame,
   t1.id_table,
   t1.periodicidade,
   t3.data_extracao,
   CASE
      WHEN(NOW() < (t3.data_extracao + (INTERVAL '1 min' * t1.periodicidade))) 
      THEN 'yes' ELSE 'no'
   END
FROM table1 AS t1
LEFT JOIN liame_has_extracao AS t2 USING(id_liame)
LEFT JOIN extracao AS t3 USING(id_extracao)

Как вы можете видеть, вы можете умножать интервалы с целыми числами, поэтому с INTERVAL '1 minute' вы определяете свой базовый блок и умножаете фактический интервал времени.

Надеюсь, что поможет