ORDER BY

Estadísticas resumidas y funciones de ventana de PostgreSQL

Michel Semaan

Data Scientist

Números de fila

Consulta

SELECT
  Year, Event, Country,
  ROW_NUMBER() OVER () AS Row_N
FROM Summer_Medals
WHERE
  Medal = 'Gold';

Resultado*

| Year | Event                      | Country | Row_N |
|------|----------------------------|---------|-------|
| 1896 | 100M Freestyle             | HUN     | 1     |
| 1896 | 100M Freestyle For Sailors | GRE     | 2     |
| 1896 | 1200M Freestyle            | HUN     | 3     |
| ...  | ...                        | ...     | ...   |
Estadísticas resumidas y funciones de ventana de PostgreSQL

Introduce ORDER BY

  • ORDER BY en OVER ordena las filas relacionadas con la fila actual
    • Ejemplo: ordenar por año en orden descendente en la cláusula OVER de ROW_NUMBER asignará 1 a las filas del año más reciente.
Estadísticas resumidas y funciones de ventana de PostgreSQL

Ordenar por año en orden descendente

Consulta

SELECT
  Year, Event, Country,
  ROW_NUMBER() OVER (ORDER BY Year DESC) AS Row_N
FROM Summer_Medals
WHERE
  Medal = 'Gold';

Resultado

| Year | Event         | Country | Row_N |
|------|---------------|---------|-------|
| 2012 | Wg 96 KG      | IRI     | 1     |
| 2012 | 4X100M Medley | USA     | 2     |
| 2012 | Wg 84 KG      | RUS     | 3     |
| ...  | ...           | ...     | ...   |
| 2008 | 50M Freestyle | BRA     | 637   |
| 2008 | 96 - 120KG    | CUB     | 638   |
| ...  | ...           | ...     | ...   |
Estadísticas resumidas y funciones de ventana de PostgreSQL

Ordenar por varias columnas

Consulta

SELECT
  Year, Event, Country,
  ROW_NUMBER() OVER
    (ORDER BY Year DESC, Event ASC) AS Row_N
FROM Summer_Medals
WHERE
  Medal = 'Gold';

Resultado

| Year | Event   | Country | Row_N |
|------|---------|---------|-------|
| 2012 | + 100KG | FRA     | 1     |
| 2012 | + 67 KG | SRB     | 2     |
| 2012 | + 78KG  | CUB     | 3     |
| ...  | ...     | ...     | ...   |
Estadísticas resumidas y funciones de ventana de PostgreSQL

Ordenar dentro y fuera OVER

Consulta

SELECT
  Year, Event, Country,
  ROW_NUMBER() OVER
    (ORDER BY Year DESC, Event ASC) AS Row_N
FROM Summer_Medals
WHERE
  Medal = 'Gold'
ORDER BY Country ASC, Row_N ASC;

Resultado

| Year | Event   | Country | Row_N |
|------|---------|---------|-------|
| 2012 | 1500M   | ALG     | 36    |
| 2000 | 1500M   | ALG     | 1998  |
| 1996 | 1500M   | ALG     | 2662  |
| ...  | ...     | ...     | ...   |
  • ORDER BY dentro OVER se aplica antes de ORDER BY fuera de OVER.
Estadísticas resumidas y funciones de ventana de PostgreSQL

Campeón reinante

  • Un campeón reinante es un campeón que ha ganado las competiciones del año anterior y del año actual.
  • Los campeones del año anterior y del año actual deben estar en la misma fila (en dos columnas diferentes).

Introduce LAG

  • LAG(column, n) OVER (...) devuelve el valor de column en la fila n antes de la fila actual
    • LAG(column, 1) OVER (...) devuelve el valor de la fila anterior
Estadísticas resumidas y funciones de ventana de PostgreSQL

Campeones actuales

Consulta

SELECT
  Year, Country AS Champion
FROM Summer_Medals
WHERE
  Year IN (1996, 2000, 2004, 2008, 2012)
  AND Gender = 'Men' AND Medal = 'Gold'
  AND Event = 'Discus Throw';

Resultado

| Year | Champion |
|------|----------|
| 1996 | GER      |
| 2000 | LTU      |
| 2004 | LTU      |
| 2008 | EST      |
| 2012 | GER      |
Estadísticas resumidas y funciones de ventana de PostgreSQL

Campeones actuales y últimos

Consulta

WITH Discus_Gold AS (
  SELECT
    Year, Country AS Champion
  FROM Summer_Medals
  WHERE
    Year IN (1996, 2000, 2004, 2008, 2012)
    AND Gender = 'Men' AND Medal = 'Gold'
    AND Event = 'Discus Throw')

SELECT
  Year, Champion,
  LAG(Champion, 1) OVER
    (ORDER BY Year ASC) AS Last_Champion
FROM Discus_Gold
ORDER BY Year ASC;

Resultado

| Year | Champion | Last_Champion |
|------|----------|---------------|
| 1996 | GER      | null          |
| 2000 | LTU      | GER           |
| 2004 | LTU      | LTU           |
| 2008 | EST      | LTU           |
| 2012 | GER      | EST           |
Estadísticas resumidas y funciones de ventana de PostgreSQL

¡Vamos a practicar!

Estadísticas resumidas y funciones de ventana de PostgreSQL

Preparing Video For Download...