Statistiques récapitulatives et fonctions de fenêtrage PostgreSQL
Michel Semaan
Data Scientist
Requête
SELECT
Country, Medal, COUNT(*) AS Awards
FROM summer_medals
WHERE
Year = 2008 AND Country IN ('CHN', 'RUS')
GROUP BY ROLLUP(Country, Medal)
ORDER BY Country ASC, Medal ASC;
null représente les totaux du groupeRésultat
| Country | Medal | Awards |
|---------|--------|--------|
| CHN | Bronze | 57 |
| CHN | Gold | 74 |
| CHN | Silver | 53 |
| CHN | null | 184 |
| RUS | Bronze | 56 |
| RUS | Gold | 43 |
| RUS | Silver | 44 |
| RUS | null | 143 |
| null | null | 327 |
COALESCE() prend une liste de valeurs et renvoie la première valeur non null, en procédant de gauche à droiteCOALESCE(null, null, 1, null, 2) → 1nullROLLUP et CUBELAG et LEADRequête
SELECT
COALESCE(Country, 'Both countries') AS Country,
COALESCE(Medal, 'All medals') AS Medal,
COUNT(*) AS Awards
FROM summer_medals
WHERE
Year = 2008 AND Country IN ('CHN', 'RUS')
GROUP BY ROLLUP(Country, Medal)
ORDER BY Country ASC, Medal ASC;
Résultat
| Country | Medal | Awards |
|----------------|------------|--------|
| Both countries | All medals | 327 |
| CHN | All medals | 184 |
| CHN | Bronze | 57 |
| CHN | Gold | 74 |
| CHN | Silver | 53 |
| RUS | All medals | 143 |
| RUS | Bronze | 56 |
| RUS | Gold | 43 |
| RUS | Silver | 44 |
Avant
| Country | Rank |
|---------|------|
| CHN | 1 |
| RUS | 2 |
| USA | 3 |
Rank est redondant car le classement est impliciteAprès
CHN, RUS, USA
STRING_AGG(column, separator) prend toutes les valeurs d'une colonne et les concatène, en insérant un separator entre chaque valeurSTRING_AGG(Letter, ', ') transforme ceci…
| Letter |
|--------|
| A |
| B |
| C |
…en ceci
A, B, C
Avant
WITH Country_Medals AS (
SELECT
Country, COUNT(*) AS Medals
FROM Summer_Medals
WHERE Year = 2012
AND Country IN ('CHN', 'RUS', 'USA')
AND Medal = 'Gold'
AND Sport = 'Gymnastics'
GROUP BY Country),
SELECT
Country,
RANK() OVER (ORDER BY Medals DESC) AS Rank
FROM Country_Medals
ORDER BY Rank ASC;
Après
WITH Country_Medals AS (...),
Country_Ranks AS (...)
SELECT STRING_AGG(Country, ', ')
FROM Country_Medals;
Résultat
CHN, RUS, USA
Statistiques récapitulatives et fonctions de fenêtrage PostgreSQL