SQL intermédiaire avec l’IA
Jasmin Ludolf
Senior Data Science Content Developer
Quelles langues ont plus de 20 films ?
WHERE
$$
$$
$$
HAVING
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 |
$$
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 |
...
Invite : Afficher les langues avec plus de 5 films depuis 2000, où la durée moyenne dépasse 80
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 filmsWHERE release_year >= 2000GROUP BY language
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
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 languageHAVING COUNT(*) > 5 AND ROUND(AVG(duration)) > 80;
|language|film_count|average_duration|
|--------|----------|----------------|
|Mandarin|26 |112 |
|Japanese|10 |114 |
|Spanish |37 |107 |
...
$$
FROM ➝

$$
FROM ➝ WHERE ➝

$$
FROM ➝ WHERE ➝ GROUP BY (et agrégation) ➝

$$
FROM ➝ WHERE ➝ GROUP BY (et agrégation) ➝ HAVING ➝

$$
FROM ➝ WHERE ➝ GROUP BY (et agrégation) ➝ HAVING ➝ SELECT ➝

$$
FROM ➝ WHERE ➝ GROUP BY (et agrégation) ➝ HAVING ➝ SELECT ➝ ORDER BY ➝

$$
FROM ➝ WHERE ➝ GROUP BY (et agrégation) ➝ HAVING ➝ SELECT ➝ ORDER BY ➝ LIMIT

Les deux : Films depuis 2000 où la durée moyenne est supérieure à 80
WHERE : Enregistrements individuels
HAVING : Mentionne l'agrégat

$$
1) Commencez petit
2) Vérifiez les résultats
3) Invitez à nouveau pour plus de détails
4) Répétez !

SQL intermédiaire avec l’IA