CommencerCommencer gratuitement

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

Afficher le cours

Instructions

  • Dans une fonction AVG(), complétez l'instruction CASE en vérifiant si m.home_goal n'est pas égal à m.away_goal, et en attribuant la valeur 0 si cette condition est remplie.
  • Répétez la procédure pour comparer les buts marqués à domicile et à l'extérieur en '2014/2015', ou ties_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;
Modifier et exécuter le code