Subkueri berkorelasi

Manipulasi Data di SQL

Mona Khalil

Data Scientist, Greenhouse Software

Subkueri berkorelasi

  • Menggunakan nilai dari kueri luar untuk menghasilkan hasil
  • Dijalankan ulang untuk setiap baris di hasil akhir
  • Untuk penggabungan, pemfilteran, dan evaluasi lanjutan
Manipulasi Data di SQL

Contoh sederhana

  • Tahap pertandingan mana yang cenderung memiliki jumlah gol di atas rata-rata?
SELECT 
    s.stage,
    ROUND(s.avg_goals,2) AS avg_goal,
    (SELECT AVG(home_goal + away_goal) FROM match 
     WHERE season = '2012/2013') AS overall_avg 
FROM 
    (SELECT
         stage,
         AVG(home_goal + away_goal) AS avg_goals
     FROM match
     WHERE season = '2012/2013'
     GROUP BY stage) AS s
WHERE s.avg_goals > (SELECT AVG(home_goal + away_goal) 
                     FROM match 
                     WHERE season = '2012/2013');
Manipulasi Data di SQL

Contoh sederhana

  • Tahap pertandingan mana yang cenderung memiliki jumlah gol di atas rata-rata?
SELECT 
    s.stage,
    ROUND(s.avg_goals,2) AS avg_goal,
    (SELECT AVG(home_goal + away_goal) 
     FROM match 
     WHERE season = '2012/2013') AS overall_avg 
FROM (SELECT
        stage,
        AVG(home_goal + away_goal) AS avg_goals
      FROM match
      WHERE season = '2012/2013'
      GROUP BY stage) AS s -- Subkueri di FROM
WHERE s.avg_goals > (SELECT AVG(home_goal + away_goal) 
                     FROM match 
                     WHERE season = '2012/2013'); -- Subkueri di WHERE
Manipulasi Data di SQL

Contoh berkorelasi

SELECT
    s.stage,
    ROUND(s.avg_goals,2) AS avg_goal,
    (SELECT AVG(home_goal + away_goal) 
     FROM match 
     WHERE season = '2012/2013') AS overall_avg 
FROM 
    (SELECT
         stage,
         AVG(home_goal + away_goal) AS avg_goals
     FROM match
     WHERE season = '2012/2013'
     GROUP BY stage) AS s
WHERE s.avg_goals > (SELECT AVG(home_goal + away_goal) 
                     FROM match AS m 
                     WHERE s.stage > m.stage);
Manipulasi Data di SQL

Contoh berkorelasi

| stage | avg_goals |
|-------|-----------|
| 3     | 2.83      |
| 4     | 2.8       |
| 6     | 2.78      |
| 8     | 3.09      |
| 10    | 2.96      |
Manipulasi Data di SQL

Subkueri sederhana vs. berkorelasi

Subkueri Sederhana

  • Dapat dijalankan mandiri dari kueri utama
  • Dievaluasi sekali untuk seluruh kueri

Subkueri Berkorelasi

  • Bergantung pada kueri utama untuk berjalan
  • Dievaluasi berulang (loop)
    • Secara signifikan memperlambat waktu eksekusi
Manipulasi Data di SQL

Subkueri berkorelasi

  • Berapa rata-rata gol yang dicetak di tiap negara?
SELECT
  c.name AS country,
  AVG(m.home_goal + m.away_goal) 
     AS avg_goals
FROM country AS c
LEFT JOIN match AS m
ON c.id = m.country_id
GROUP BY country;
| country     | avg_goals        |
|-------------|------------------|
| Belgium     | 2.89344262295082 |
| England     | 2.76776315789474 |
| France      | 2.51052631578947 |
| Germany     | 2.94607843137255 |
| Italy       | 2.63150867823765 |
| Netherlands | 3.14624183006536 |
| Poland      | 2.49375          |
| Portugal    | 2.63255360623782 |
| Scotland    | 2.74122807017544 |
| Spain       | 2.78223684210526 |
| Switzerland | 2.81054131054131 |
Manipulasi Data di SQL

Subkueri berkorelasi

  • Berapa rata-rata gol yang dicetak di tiap negara?
SELECT
  c.name AS country,
  (SELECT 
     AVG(home_goal + away_goal)
   FROM match AS m
   WHERE m.country_id = c.id) 
     AS avg_goals
FROM country AS c
GROUP BY country;
| country     | avg_goals        |
|-------------|------------------|
| Belgium     | 2.89344262295082 |
| England     | 2.76776315789474 |
| France      | 2.51052631578947 |
| Germany     | 2.94607843137255 |
| Italy       | 2.63150867823765 |
| Netherlands | 3.14624183006536 |
| Poland      | 2.49375          |
| Portugal    | 2.63255360623782 |
| Scotland    | 2.74122807017544 |
| Spain       | 2.78223684210526 |
| Switzerland | 2.81054131054131 |
Manipulasi Data di SQL

Ayo berlatih!

Manipulasi Data di SQL

Preparing Video For Download...