sql >> Database teknologi >  >> RDS >> PostgreSQL

Hent sidst kendte værdi for hver kolonne i en række

Her laver jeg en aggregeringsfunktion, der samler kolonner i arrays. Så er det bare et spørgsmål om at fjerne NULL'erne og vælge det sidste element fra hvert array.

Eksempel på data

CREATE TABLE T (
    date_time timestamp,
    a text,
    b text,
    c text
);

INSERT INTO T VALUES ('2013-10-15 11:45:00', NULL, 'timtim', 'fred'),
('2013-10-15 13:00:00', 'tune', 'reco', NULL  ),
('2013-10-16 12:00:00', 'abc', NULL, NULL     ),
('2013-10-16 13:00:00', NULL, 'died', NULL    );
 

Løsning

CREATE AGGREGATE array_accum (anyelement)
(
    sfunc = array_append,
    stype = anyarray,
    initcond = '{}'
);

WITH latest_nonull AS (
    SELECT MAX(date_time) As MaxDateTime, 
           array_remove(array_accum(a), NULL) AS A, 
           array_remove(array_accum(b), NULL) AS B, 
           array_remove(array_accum(c), NULL) AS C
    FROM T
    ORDER BY date_time
)
SELECT MaxDateTime, A[array_upper(A, 1)], B[array_upper(B,1)], C[array_upper(C,1)]
FROM latest_nonull;
 

Resultat

maxdatetime | a | b | c ---------------------+-----+------+------ 2013-10-16 13:00:00 | abc | died | fred (1 row)

  1. Sådan kontrolleres, om der findes en tabel i SQLite

  2. PDO MySQL:Brug PDO::ATTR_EMULATE_PREPARES eller ej?

  3. Grupperet sammenkædning i SQL Server

  4. Java SQLData - Cast til brugerobjekt med en liste/array?