PostgreSQL
 sql >> Base de Dados >  >> RDS >> PostgreSQL

Como faço para iterar uma tabela de acordo com intervalos de tempo fixos no Postgres?


Esta é uma facada em uma resposta. Ele realmente precisa de dados mais completos para ser levado a sério. Aqui vai:
SELECT
    *, 1 AS flag
FROM
(SELECT
    *,
    valuenum - LAG(valuenum, 1) OVER(partition by item) AS diff,
    intime - LAG(intime, 1) OVER(partition by item) AS time_diff
FROM
    lab L
JOIN
    icu I
ON
    L.id_sub = I.id
WHERE
    L.item = 50912
AND
    L.charttime < I.intime AND L.charttime > (I.intime - INTERVAL '7 DAY')
) AS select_diff

WHERE
    select_diff.diff > 0.3
AND
    select_diff.time_diff <interval '48 hours';