Gasto por cliente com subconsultas

Tomada de decisão orientada por dados em SQL

Tim Verdonck

Professor Statistics and Data Science

SELECTs subsequentes - atrizes

Consulta 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 |
Tomada de decisão orientada por dados em SQL

SELECTs subsequentes - atrizes

SELECT * -- Query 1
FROM actors
WHERE gender = 'female';
  • Agrupa o resultado da consulta 1 por nacionalidade.
  • Mostra o ano de nascimento da atriz mais velha e da mais nova em cada país.
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;
Tomada de decisão orientada por dados em SQL

Resultado do SELECT subsequente - atrizes

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 |
Tomada de decisão orientada por dados em SQL

Quanto cada cliente gastou?

  • Passo 1: Adicionar renting_price de movies à tabela 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          |
Tomada de decisão orientada por dados em SQL

Quanto cada cliente gastou?

  • Passo 2:
    • agrupa o resultado do passo 1 por customer_id
    • soma 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;
Tomada de decisão orientada por dados em SQL

Quanto cada cliente gastou?

| customer_id | sum   |
|-------------|-------|
| 116         | 7.47  |
| 87          | 17.53 |
| 71          | 6.87  |
| 68          | 1.59  |
| 51          | 4.87  |
Tomada de decisão orientada por dados em SQL

Vamos praticar!

Tomada de decisão orientada por dados em SQL

Preparing Video For Download...