Filteren en sorteren

Data-driven beslissingen nemen met SQL

Tim Verdonck

Professor Statistics and Data Science

WHERE

Selecteer alle klanten uit Italië:

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        |
Data-driven beslissingen nemen met SQL

Operatoren in de WHERE-clausule

  • Vergelijkingsoperatoren:
    • Gelijk =
    • Ongelijk <>
    • Kleiner dan <
    • Kleiner of gelijk <=
    • Groter dan >
    • Groter of gelijk >=
  • BETWEEN-operator
  • IN-operator
  • IS NULL- en IS NOT NULL-operatoren
Data-driven beslissingen nemen met SQL

Voorbeeld vergelijkingsoperatoren

Selecteer alle kolommen uit movies waar het genre niet Drama is.

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

Selecteer alle kolommen uit movies waar de huurprijs minstens 2 is.

SELECT *
FROM movies
WHERE renting_price >= 2;
Data-driven beslissingen nemen met SQL

Voorbeeld: BETWEEN-operator

Selecteer alle kolommen van customers waar de accountdatum tussen 2018-01-01 en 2018-09-30 ligt.

SELECT *
FROM customers
WHERE date_account_start BETWEEN '2018-01-01' AND '2018-09-30';
Data-driven beslissingen nemen met SQL

Voorbeeld: IN-operator

Selecteer alle acteurs met nationaliteit VS of Australië.

SELECT *
FROM actors
WHERE nationality IN ('USA', 'Australia')
Data-driven beslissingen nemen met SQL

Voorbeeld: NULL-operator

Selecteer alle kolommen uit renting waar rating NULL is.

SELECT *
FROM renting
WHERE rating IS NULL

Selecteer alle kolommen uit renting waar rating niet NULL is.

SELECT *
FROM renting
WHERE rating IS NOT NULL
Data-driven beslissingen nemen met SQL

Booleaanse operator AND

Selecteer klantnaam en de datum waarop het account is aangemaakt voor klanten uit Italië _EN_ die een account maakten tussen 2018-01-01 en 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         |
Data-driven beslissingen nemen met SQL

Booleaanse operator OR

Selecteer klantnaam en de datum waarop het account is aangemaakt voor klanten uit Italië _OF_ die een account maakten tussen 2018-01-01 en 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         |
| ...                   | ...     | ...                |
Data-driven beslissingen nemen met SQL

ORDER BY

Sorteer de queryresultaten op 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   |
Data-driven beslissingen nemen met SQL

ORDER BY ... DESC

Sorteer de queryresultaten op rating in aflopende volgorde.

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   |
Data-driven beslissingen nemen met SQL

Laten we oefenen!

Data-driven beslissingen nemen met SQL

Preparing Video For Download...