sql >> Database >  >> RDS >> PostgreSQL

PostgreSQL-waarde uit vorige rij gebruiken als deze ontbreekt

Je kunt een self-join en Windows-functies combineren

Vereenvoudigend neem ik deze tabel met deze voorbeeldwaarden:

create table t ( a int, b int);    
insert into t values 
( 1, 1),
( 2, Null),
( 3, Null),
( 4, 2 ),
( 5, Null),
( 6, Null);

In uw zoekopdracht a is trunc_u en b is uw id .De vraag is:

with cte as (    
    select 
      t1.a, 
      coalesce( t1.b, t2.b, 0) as b,
      rank() OVER 
       (PARTITION BY t1.a ORDER BY t2.a DESC) as pos
    from t t1 
    left outer join t t2
      on t2.b is not null and
         t2.a < t1.a    
)
select a, b
from cte
where pos = 1;

En resultaten:

| A | B |
---------
| 1 | 1 |
| 2 | 1 |
| 3 | 1 |
| 4 | 2 |
| 5 | 2 |
| 6 | 2 |


  1. Best practice:importeer mySQL-bestand in PHP; gesplitste zoekopdrachten

  2. Waar slaat PostgreSQL de database op?

  3. sqlplus hoe details van de momenteel verbonden databasesessie te vinden

  4. Datums vergelijken die zijn opgeslagen als varchar