İç içe sorgu

SQL ile Veri Odaklı Karar Verme

Irene Ortner

Data Scientist at Applied Statistics

İç içe sorgu

  • WHERE veya HAVING içinde SELECT bloğu
  • İç sorgu tek ya da çoklu değer döndürür
  • İç sorgunun sonucunu başka bir sorguda belirli satırları seçmek için kullanın
SQL ile Veri Odaklı Karar Verme

İç sorgu

Adım 1: İç sorgu

SELECT DISTINCT customer_id
FROM renting
WHERE rating <= 3
| customer_id |
|-------------|
| 28          |
| 41          |
| 86          |
| 120         |
SQL ile Veri Odaklı Karar Verme

Sonuç WHERE koşulunda

SELECT name
FROM customers
WHERE customer_id IN (28, 41, 86, 120);
SQL ile Veri Odaklı Karar Verme

Dış sorgu

Adım 2: Dış sorgu

SELECT name
FROM customers
WHERE customer_id IN
    (SELECT DISTINCT customer_id
    FROM renting
    WHERE rating <= 3);
| name            |
|-----------------|
| Sidney Généreux |
| Zara Mitchell   |
SQL ile Veri Odaklı Karar Verme

HAVING koşulunda iç içe sorgu

Adım 1: İç sorgu

SELECT MIN(date_account_start)
FROM customers
WHERE country = 'Austria';
| min        |
|------------|
| 2017-11-22 |
SQL ile Veri Odaklı Karar Verme

HAVING koşulunda iç içe sorgu

Adım 2: Dış sorgu

SELECT country, MIN(date_account_start)
FROM customers
GROUP BY country
HAVING MIN(date_account_start) <
    (SELECT MIN(date_account_start)
    FROM customers
    WHERE country = 'Austria');
| country       | min        |
|---------------|------------|
| Spain         | 2017-02-14 |
| Great Britain | 2017-03-31 |
SQL ile Veri Odaklı Karar Verme

Ray filmindeki oyuncular kimler?

SELECT name
FROM actors
WHERE actor_id IN
    (SELECT actor_id 
     FROM actsin
     WHERE movie_id =
        (SELECT movie_id 
         FROM movies
         WHERE title='Ray'));
| name             |
|------------------|
| Jamie Foxx       |
| Kerry Washington |
| Regina King      |
SQL ile Veri Odaklı Karar Verme

Haydi pratik yapalım!

SQL ile Veri Odaklı Karar Verme

Preparing Video For Download...