ORDER BY

Ringkasan Statistik dan Window Functions di PostgreSQL

Michel Semaan

Data Scientist

Nomor baris

Kueri

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

Hasil*

| Year | Event                      | Country | Row_N |
|------|----------------------------|---------|-------|
| 1896 | 100M Freestyle             | HUN     | 1     |
| 1896 | 100M Freestyle For Sailors | GRE     | 2     |
| 1896 | 1200M Freestyle            | HUN     | 3     |
| ...  | ...                        | ...     | ...   |
Ringkasan Statistik dan Window Functions di PostgreSQL

Masuk ORDER BY

  • ORDER BY dalam OVER mengurutkan baris yang terkait dengan baris saat ini
    • Contoh: Mengurutkan tahun menurun dalam klausa OVER milik ROW_NUMBER akan memberi 1 pada baris tahun terbaru
Ringkasan Statistik dan Window Functions di PostgreSQL

Mengurutkan Year menurun

Kueri

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

Hasil

| 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   |
| ...  | ...           | ...     | ...   |
Ringkasan Statistik dan Window Functions di PostgreSQL

Mengurutkan berdasarkan beberapa kolom

Kueri

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

Hasil

| Year | Event   | Country | Row_N |
|------|---------|---------|-------|
| 2012 | + 100KG | FRA     | 1     |
| 2012 | + 67 KG | SRB     | 2     |
| 2012 | + 78KG  | CUB     | 3     |
| ...  | ...     | ...     | ...   |
Ringkasan Statistik dan Window Functions di PostgreSQL

Pengurutan di dalam dan di luar OVER

Kueri

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;

Hasil

| Year | Event   | Country | Row_N |
|------|---------|---------|-------|
| 2012 | 1500M   | ALG     | 36    |
| 2000 | 1500M   | ALG     | 1998  |
| 1996 | 1500M   | ALG     | 2662  |
| ...  | ...     | ...     | ...   |
  • ORDER BY di dalam OVER berlaku lebih dulu daripada ORDER BY di luar OVER
Ringkasan Statistik dan Window Functions di PostgreSQL

Juara bertahan

  • Juara bertahan adalah juara yang menang pada tahun sebelumnya dan tahun berjalan
  • Juara tahun sebelumnya dan tahun berjalan harus berada pada baris yang sama (di dua kolom berbeda)

Masuk LAG

  • LAG(column, n) OVER (...) mengembalikan nilai column pada baris n baris sebelum baris saat ini
    • LAG(column, 1) OVER (...) mengembalikan nilai baris sebelumnya
Ringkasan Statistik dan Window Functions di PostgreSQL

Juara saat ini

Kueri

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';

Hasil

| Year | Champion |
|------|----------|
| 1996 | GER      |
| 2000 | LTU      |
| 2004 | LTU      |
| 2008 | EST      |
| 2012 | GER      |
Ringkasan Statistik dan Window Functions di PostgreSQL

Juara saat ini dan sebelumnya

Kueri

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;

Hasil

| Year | Champion | Last_Champion |
|------|----------|---------------|
| 1996 | GER      | null          |
| 2000 | LTU      | GER           |
| 2004 | LTU      | LTU           |
| 2008 | EST      | LTU           |
| 2012 | GER      | EST           |
Ringkasan Statistik dan Window Functions di PostgreSQL

Ayo berlatih!

Ringkasan Statistik dan Window Functions di PostgreSQL

Preparing Video For Download...