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

Sumuj według miesiąca i wstawiaj miesiące jako kolumny

Możesz użyć funkcji agregującej z CASE wyrażenie do zamiany wierszy na kolumny:

select id,
  extra_info,
  sum(case when month = 'jan' then value else 0 end) jan,
  sum(case when month = 'feb' then value else 0 end) feb,
  sum(case when month = 'mar' then value else 0 end) mar,
  sum(case when month = 'apr' then value else 0 end) apr,
  sum(case when month = 'may' then value else 0 end) may,
  sum(case when month = 'jun' then value else 0 end) jun,
  sum(case when month = 'jul' then value else 0 end) jul,
  sum(case when month = 'aug' then value else 0 end) aug,
  sum(case when month = 'sep' then value else 0 end) sep,
  sum(case when month = 'oct' then value else 0 end) oct,
  sum(case when month = 'nov' then value else 0 end) nov,
  sum(case when month = 'dec' then value else 0 end) "dec"
from yt
group by id, extra_info

Zobacz Skrzypce SQL z wersją demonstracyjną



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. PostgreSQL wiersz do kolumn

  2. Zapytanie zwracające dokładną liczbę wierszy

  3. Usuwanie komentarza COMMENT ON ze wszystkich obiektów w PostgreSQL

  4. Refaktoryzuj klucz obcy do pól

  5. ustaw poziom izolacji dla procedur składowanych postgresql