Utilisation de CASE et AVG pour dériver des fractions
Les instructions CASE renverront toutes les valeurs spécifiées dans la clause THEN. Cet outil est incroyablement puissant pour les calculs et la manipulation complexes de données lorsqu’il est utilisé avec une instruction agrégée. Vous pouvez utiliser CASE dans une fonction AVG pour calculer une fraction des informations contenues dans votre base de données.
Voici un exemple de la manière dont vous pouvez configurer cela :
AVG(CASE WHEN condition_is_met THEN 1
WHEN condition_is_not_met THEN 0 END)
Avec cette approche, il est important de préciser les enregistrements ayant la valeur 0. Sinon, vos calculs risquent d’être incorrects !
Votre tâche consiste à examiner le nombre de victoires, de défaites et de matchs nuls dans chaque pays. La table matches est filtrée pour inclure tous les matchs des saisons 2013/2014 et 2014/2015.
Cet exercice fait partie du cours
Manipulation de données en SQL
Instructions
- Dans une fonction
AVG(), complétez l'instructionCASEen vérifiant sim.home_goaln'est pas égal àm.away_goal, et en attribuant la valeur0si cette condition est remplie. - Répétez la procédure pour comparer les buts marqués à domicile et à l'extérieur en
'2014/2015', outies_2014_2015.
Exercice interactif pratique
Essayez cet exercice en complétant cet exemple de code.
SELECT
c.name AS country,
-- Calculate the fraction of tied games in each season
___(___ ___ m.season='2013/2014' AND m.home_goal = m.away_goal THEN 1
WHEN m.season='2013/2014' AND m.home_goal ___ m.away_goal THEN ___
END) AS ties_2013_2014,
___(___ ___ m.season='2014/2015' ___ ___ = ___ ___ ___
WHEN m.season='2014/2015' ___ m.home_goal != m.away_goal THEN ___
___) AS ___
FROM country AS c
LEFT JOIN matches AS m
ON c.id = m.country_id
GROUP BY country;