Alt sorgularla müşteri başına harcama

SQL ile Veri Odaklı Karar Verme

Tim Verdonck

Professor Statistics and Data Science

Ardışık SELECT ifadeleri - aktrisler

Sorgu 1:

SELECT *
FROM actors
WHERE gender = 'female';
| actor_id | name          | year_of_birth | nationality | gender |
|----------|---------------|---------------|-------------|--------|
| 1        | Abbie Cornish | 1982          | Australia   | female |
| 4        | Amy Adams     | 1974          | USA         | female |
SQL ile Veri Odaklı Karar Verme

Ardışık SELECT ifadeleri - aktrisler

SELECT * -- Query 1
FROM actors
WHERE gender = 'female';
  • Sorgu 1’in sonuç tablosunu nationality sütununa göre gruplayın.
  • Her ülkedeki en yaşlı ve en genç aktrisin doğum yılını raporlayın.
SELECT af.nationality, 
       MIN(af.year_of_birth), 
       MAX(af.year_of_birth)
FROM
    (SELECT *
    FROM actors
    WHERE gender = 'female') AS af
GROUP BY af.nationality;
SQL ile Veri Odaklı Karar Verme

Ardışık SELECT sonucu - aktrisler

SELECT af.nationality, 
       MIN(af.year_of_birth), 
       MAX(af.year_of_birth)
FROM
    (SELECT *
    FROM actors
    WHERE gender = 'female') AS af
GROUP BY af.nationality;
| nationality | min  | max  |
|-------------|------|------|
| Italy       | 1976 | 1976 |
| Iran        | 1952 | 1952 |
| USA         | 1945 | 1993 |
SQL ile Veri Odaklı Karar Verme

Her müşteri ne kadar harcadı?

  • İlk adım: movies tablosundaki renting_price değerini renting tablosuna ekleyin.
SELECT r.customer_id,
       m.renting_price
FROM renting AS r
LEFT JOIN movies AS m
ON r.movie_id=m.movie_id;
| customer_id | renting_price |
|-------------|---------------|
| 41          | 2.59          |
| 10          | 2.79          |
| 108         | 2.39          |
| 39          | 1.59          |
| 104         | 1.69          |
SQL ile Veri Odaklı Karar Verme

Her müşteri ne kadar harcadı?

  • İkinci adım:
    • ilk adımın sonuç tablosunu customer_id ile gruplayın
    • renting_price toplamını alın
SELECT rm.customer_id, 
           SUM(rm.renting_price)
FROM
       (SELECT r.customer_id, 
               m.renting_price
       FROM renting AS r
       LEFT JOIN movies AS m
       ON r.movie_id=m.movie_id) AS rm
GROUP BY rm.customer_id;
SQL ile Veri Odaklı Karar Verme

Her müşteri ne kadar harcadı?

| customer_id | sum   |
|-------------|-------|
| 116         | 7.47  |
| 87          | 17.53 |
| 71          | 6.87  |
| 68          | 1.59  |
| 51          | 4.87  |
SQL ile Veri Odaklı Karar Verme

Haydi pratik yapalım!

SQL ile Veri Odaklı Karar Verme

Preparing Video For Download...