Filtrando e ordenando

Tomada de decisão orientada por dados em SQL

Tim Verdonck

Professor Statistics and Data Science

WHERE

Selecione todos os clientes da Itália:

SELECT *
FROM customers
WHERE country = 'Italy';
|customer_id | name              | country | gender | date_of_birth | date_account_start|
|------------|-------------------|---------|--------|---------------|-------------------|
| 53         | Teresio Panicucci | Italy   | male   | 1999-07-21    | 2018-11-06        |
| 54         | Demetrio Palermo  | Italy   | male   | 1997-10-10    | 2018-10-17        |
| 55         | Facino Milano     | Italy   | male   | 1973-05-23    | 2018-01-02        |
Tomada de decisão orientada por dados em SQL

Operadores na cláusula WHERE

  • Operadores de comparação:
    • Igual =
    • Diferente <>
    • Menor que <
    • Menor ou igual <=
    • Maior que >
    • Maior ou igual >=
  • Operador BETWEEN
  • Operador IN
  • Operadores IS NULL e IS NOT NULL
Tomada de decisão orientada por dados em SQL

Exemplo: operadores de comparação

Selecione todas as colunas de movies onde o gênero não é Drama.

SELECT *
FROM movies
WHERE genre <> 'Drama';

Selecione todas as colunas de movies onde o preço de aluguel é maior ou igual a 2.

SELECT *
FROM movies
WHERE renting_price >= 2;
Tomada de decisão orientada por dados em SQL

Exemplo: operador BETWEEN

Selecione todas as colunas de customers onde a data de criação da conta está entre 2018-01-01 e 2018-09-30.

SELECT *
FROM customers
WHERE date_account_start BETWEEN '2018-01-01' AND '2018-09-30';
Tomada de decisão orientada por dados em SQL

Exemplo: operador IN

Selecione todos os atores com nacionalidade EUA ou Austrália.

SELECT *
FROM actors
WHERE nationality IN ('USA', 'Australia')
Tomada de decisão orientada por dados em SQL

Exemplo: operador NULL

Selecione todas as colunas de renting onde rating é NULL.

SELECT *
FROM renting
WHERE rating IS NULL

Selecione todas as colunas de renting onde rating não é NULL.

SELECT *
FROM renting
WHERE rating IS NOT NULL
Tomada de decisão orientada por dados em SQL

Operadores booleanos AND

Selecione o nome do cliente e a data de criação da conta para clientes da Itália E que criaram a conta entre 2018-01-01 e 2018-09-30.

SELECT name, date_account_start
FROM customers
WHERE country = 'Italy'
AND date_account_start BETWEEN '2018-01-01' AND '2018-09-30';
| name               | date_account_start |
|--------------------|--------------------|
| Facino Milano      | 2018-01-02         |
| Mario Lettiere     | 2018-01-30         |
| Rocco Buccho       | 2018-02-27         |
| Cristoforo Mancini | 2018-01-12         |
Tomada de decisão orientada por dados em SQL

Operadores booleanos OR

Selecione o nome do cliente e a data de criação da conta para clientes da Itália OU que criaram a conta entre 2018-01-01 e 2018-09-30.

SELECT name, date_account_start
FROM customers
WHERE country = 'Italy'
OR date_account_start BETWEEN '2018-01-01' AND '2018-09-30';
| name                  | country | date_account_start |
|-----------------------|-------- |--------------------|
| Rowanne Couperus      | Belgium | 2018-08-26         |
| Annelous Sneep        | Belgium | 2018-05-12         |
| Jaëla van den Dolder  | Belgium | 2018-02-08         |
| ...                   | ...     | ...                |
Tomada de decisão orientada por dados em SQL

ORDER BY

Ordene os resultados por rating.

SELECT *
FROM renting
WHERE rating IS NOT NULL
ORDER BY rating;
| renting_id | customer_id | movie_id | rating | date_renting |
|------------|-------------|----------|--------|--------------|
| 552        | 28          | 56       | 1      | 2017-03-27   |
| 558        | 41          | 19       | 3      | 2019-01-13   |
| 444        | 120         | 59       | 3      | 2018-08-10   |
| 200        | 86          | 46       | 3      | 2018-08-26   |
| 234        | 104         | 28       | 4      | 2018-10-04   |
Tomada de decisão orientada por dados em SQL

ORDER BY ... DESC

Ordene os resultados por rating em ordem decrescente.

SELECT *
FROM renting
WHERE rating IS NOT NULL
ORDER BY rating DESC;
| renting_id | customer_id | movie_id | rating | date_renting |
|------------|-------------|----------|--------|--------------|
| 243        | 7           | 5        | 10     | 2019-01-11   |
| 18         | 36          | 39       | 10     | 2019-03-20   |
| 396        | 7           | 40       | 10     | 2018-09-11   |
| 487        | 61          | 48       | 10     | 2017-08-14   |
| 476        | 78          | 42       | 10     | 2018-07-04   |
Tomada de decisão orientada por dados em SQL

Vamos praticar!

Tomada de decisão orientada por dados em SQL

Preparing Video For Download...