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)
.
Как я могу это сделать?
Ответы
Ответ 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'
вы определяете свой базовый блок и умножаете фактический интервал времени.
Надеюсь, что поможет