Filtrer les données groupées

SQL intermédiaire avec l’IA

Jasmin Ludolf

Senior Data Science Content Developer

WHERE ou HAVING

Quelles langues ont plus de 20 films ?

  • Nombre de langues : agrégé et groupé

 

WHERE

  • Lignes individuelles
  • Quels films individuels répondent à cette condition ?

$$

$$

$$

HAVING

  • Résultats groupés
  • Quels groupes répondent à cette condition ?
SQL intermédiaire avec l’IA

Filtrer les données groupées

Invite : Quelles langues ont plus de 20 films ?

SELECT language, COUNT(*) AS lang_count
FROM films
GROUP BY language
HAVING COUNT(*) > 20;
|language|
|--------|
|Mandarin|
|Spanish |
|French  |
|Hindi   |
|English |

$$

  • Filtres après :
    • Groupement
    • Agrégations
    • Quand les comptes sont disponibles
SQL intermédiaire avec l’IA

Inviter pour les filtres de groupe

Invite : Titres de films et budgets avec un budget supérieur à 5 millions

SELECT title, budget
FROM films
WHERE budget > 5000000;
|title          |budget |
|---------------|-------|
|Metropolis     |6000000|
|Duel in the Sun|8000000|
|Quo Vadis      |7623000|
|West Side Story|6000000|
...

Invite : Langues et budget avec un budget moyen arrondi supérieur à 5 millions

SELECT language, ROUND(AVG(budget)) AS avg_budget
FROM films
GROUP BY language
HAVING ROUND(AVG(budget)) > 5000000;
|language|avg_budget|
|--------|----------|
|Danish  |16700000  |
|None    |8250000   |
|Tamil   |150000000 |
...
SQL intermédiaire avec l’IA

Combiner les filtres

Invite : Afficher les langues avec plus de 5 films depuis 2000, où la durée moyenne dépasse 80

SQL intermédiaire avec l’IA

Combiner les filtres

Invite : Afficher les langues avec plus de 5 films depuis 2000, où la durée moyenne dépasse 80

SELECT language, COUNT(*) AS film_count, ROUND(AVG(duration)) AS average_duration
FROM films

WHERE release_year >= 2000
GROUP BY language
SQL intermédiaire avec l’IA

Combiner les filtres

Invite : Afficher les langues avec plus de 5 films depuis 2000, où la durée moyenne dépasse 80

SELECT language, COUNT(*) AS film_count, ROUND(AVG(duration)) AS average_duration
FROM films
WHERE release_year >= 2000
GROUP BY language

SQL intermédiaire avec l’IA

Combiner les filtres

Invite : Afficher les langues avec plus de 5 films depuis 2000, où la durée moyenne dépasse 80

SELECT language, COUNT(*) AS film_count, ROUND(AVG(duration)) AS average_duration
FROM films
WHERE release_year >= 2000
GROUP BY language

HAVING COUNT(*) > 5 AND ROUND(AVG(duration)) > 80;
|language|film_count|average_duration|
|--------|----------|----------------|
|Mandarin|26        |112             |
|Japanese|10        |114             |
|Spanish |37        |107             |
...
SQL intermédiaire avec l’IA

Ordre des opérations

$$

FROM

Une chaîne de montage

SQL intermédiaire avec l’IA

Ordre des opérations

$$

FROMWHERE

Une chaîne de montage

SQL intermédiaire avec l’IA

Ordre des opérations

$$

FROMWHEREGROUP BY (et agrégation) ➝

Une chaîne de montage

SQL intermédiaire avec l’IA

Ordre des opérations

$$

FROMWHEREGROUP BY (et agrégation) ➝ HAVING

Une chaîne de montage

SQL intermédiaire avec l’IA

Ordre des opérations

$$

FROMWHEREGROUP BY (et agrégation) ➝ HAVINGSELECT

Une chaîne de montage

SQL intermédiaire avec l’IA

Ordre des opérations

$$

FROMWHEREGROUP BY (et agrégation) ➝ HAVINGSELECTORDER BY

Une chaîne de montage

SQL intermédiaire avec l’IA

Ordre des opérations

$$

FROMWHEREGROUP BY (et agrégation) ➝ HAVINGSELECTORDER BYLIMIT

Une chaîne de montage

SQL intermédiaire avec l’IA

Invites de filtre

Les deux : Films depuis 2000 où la durée moyenne est supérieure à 80

WHERE : Enregistrements individuels

  • Titres de films sortis après 2024
  • Budgets supérieurs à 5 millions

HAVING : Mentionne l'agrégat

  • Langues avec un budget moyen supérieur à 10000
  • Nombre de films supérieur à 5

Stylo sur papier

SQL intermédiaire avec l’IA

Invitations itératives

$$

1) Commencez petit

2) Vérifiez les résultats

3) Invitez à nouveau pour plus de détails

4) Répétez !

Illustration 3D de bulles de dialogue, une avec IA et une avec des points de suspension

SQL intermédiaire avec l’IA

Temps de pratiquer !

SQL intermédiaire avec l’IA

Preparing Video For Download...