Uang yang dihabiskan per pelanggan dengan subquery

Pengambilan Keputusan Berbasis Data dengan SQL

Tim Verdonck

Professor Statistics and Data Science

Pernyataan SELECT berurutan - aktris

Kueri 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 |
Pengambilan Keputusan Berbasis Data dengan SQL

Pernyataan SELECT berurutan - aktris

SELECT * -- Query 1
FROM actors
WHERE gender = 'female';
  • Kelompokkan tabel hasil kueri 1 menurut nationality.
  • Tampilkan tahun lahir aktris tertua dan termuda di tiap negara.
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;
Pengambilan Keputusan Berbasis Data dengan SQL

Hasil SELECT berurutan - aktris

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 |
Pengambilan Keputusan Berbasis Data dengan SQL

Berapa banyak uang yang dihabiskan tiap pelanggan?

  • Langkah pertama: Tambahkan renting_price dari movies ke tabel renting.
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          |
Pengambilan Keputusan Berbasis Data dengan SQL

Berapa banyak uang yang dihabiskan tiap pelanggan?

  • Langkah kedua:
    • kelompokkan tabel hasil dari langkah pertama berdasarkan customer_id
    • jumlahkan renting_price
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;
Pengambilan Keputusan Berbasis Data dengan SQL

Berapa banyak uang yang dihabiskan tiap pelanggan?

| customer_id | sum   |
|-------------|-------|
| 116         | 7.47  |
| 87          | 17.53 |
| 71          | 6.87  |
| 68          | 1.59  |
| 51          | 4.87  |
Pengambilan Keputusan Berbasis Data dengan SQL

Ayo berlatih!

Pengambilan Keputusan Berbasis Data dengan SQL

Preparing Video For Download...