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

postgresql:opdeling af tidsperiode ved begivenhed

Du kan gøre UNION i stedet. På denne måde genererer du ikke unødvendige rækker

SELECT country, start_date, 
       CASE WHEN event_date BETWEEN start_date AND end_date 
            THEN event_date - 1 
            ELSE end_date
       END AS end_date, event_date
  FROM table1
 UNION ALL
SELECT country, event_date, end_date, event_date
  FROM table1
 WHERE event_date BETWEEN start_date AND end_date
 ORDER BY country, start_date, end_date, event_date

Her er en SQLFiddle demo

Output:

| country | start_date |   end_date | event_date |
|---------|------------|------------|------------|
|       A | 1960-01-01 | 1994-07-19 | 1994-07-20 |
|       A | 1994-07-20 | 1999-12-31 | 1994-07-20 |
|       B | 1926-01-01 | 1995-12-31 |     (null) |



  1. 4 måder at adskille timer, minutter og sekunder fra en tidsværdi i MariaDB

  2. PostgreSQL parametriseret rækkefølge efter / grænse i tabelfunktion

  3. MySQL-tabel med flere værdier i ét felt

  4. Sammenlign to MySQL-databaser