PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Postgres generate_series

Możesz napisać WITH zapytanie w tym celu:

WITH month_amount AS
(
    SELECT
        sum(amount) AS amount,
        date_trunc('month', date) AS month
    FROM Amount
    WHERE user_id = 55 -- AND ...
    GROUP BY month
)
SELECT month, amount
FROM
    (SELECT generate_series(min(month), max(month), '1 month') AS month
    FROM month_amount) x
LEFT JOIN month_amount
USING (month)
ORDER BY month;

Przykładowy wynik:

SELECT * FROM amount WHERE user_id = 55;
 amount_id | user_id | amount |    date    
-----------+---------+--------+------------
         3 |      55 |      7 | 2011-03-16
         4 |      55 |      5 | 2011-03-22
         5 |      55 |      2 | 2011-05-07
         6 |      55 |     18 | 2011-05-27
         7 |      55 |      4 | 2011-06-14
(5 rows)

WITH month_amount ..
         month          | amount 
------------------------+--------
 2011-03-01 00:00:00+01 |     12
 2011-04-01 00:00:00+02 |       
 2011-05-01 00:00:00+02 |     20
 2011-06-01 00:00:00+02 |      4
(4 rows)


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Nazwy tabel Postgresql i Unicode:Dlaczego nie mogę wybrać nazwy tabeli ze schematu informacyjnego, jeśli zawiera ona znaki Unicode?

  2. Zoptymalizuj zakres zapytań sygnatury czasowej Postgres

  3. Wyjście zapytania z wcięciem

  4. Błąd:INTO określono więcej niż raz w lub w pobliżu INTO

  5. Przełącz rolę po połączeniu z bazą danych