TOP

SQL GROUP BY

SQL GROUP BY descriptif

L'instruction GROUP BY regroupe les lignes avec les mêmes valeurs en lignes récapitulatives, telles que "trouver le nombre de clients dans chaque pays".

L'instruction GROUP BY est souvent utilisée avec des fonctions d'agrégation (COUNT(), MAX(), MIN(), SUM(), AVG()) pour regrouper un jeu de résultats par une ou plusieurs colonnes.


GROUP BY Syntaxe

SELECT column_name(s)
FROM table_name
WHERE condition
GROUP BY column_name(s)
ORDER BY column_name(s)

Base de données de démonstration

Voici un exemple de la table "Customers" ("Clients") de la base de données "Northwind" :

CustomerIDCustomerNameContactNameAddressCityPostalCodeCountry
1Alfreds FutterkisteMaria AndersObere Str. 57Berlin12209Germany
2Ana Trujillo Emparedados y heladosAna TrujilloAvda. de la Constitución 2222México D.F.5021Mexico
3Antonio Moreno TaqueríaAntonio MorenoMataderos 2312México D.F.5023Mexico
4Around the HornThomas Hardy120 Hanover Sq.LondonWA1 1DPUK
5Berglunds snabbköpChristina BerglundBerguvsvägen 8LuleåS-958 22Sweden

SQL GROUP BY Exemples

L'instruction SQL suivante répertorie le nombre de clients dans chaque pays :

Run SQLSELECT COUNT(CustomerID), Country 
FROM Customers 
GROUP BY Country

L'instruction SQL suivante répertorie les clients de chaque pays, triés du plus élevé au plus bas :

Run SQLSELECT COUNT(CustomerID), Country 
FROM Customers 
GROUP BY Country 
ORDER BY COUNT(CustomerID) DESC

Base de données de démonstration

Voici un exemple de la table "Orders" ("Commandes") de la base de données "Northwind" :

ProductIDOrderIDCustomerIDEmployeeIDOrderDateShipperID
1102489051996-07-043
2102498161996-07-051
3102503441996-07-082
4102518431996-07-081
5102527641996-07-092

Et l'exemple de la table "Shippers" ("Expéditeurs") :

ShipperIDShipperNamePhone
1Speedy Express(503) 555-9831
2United Package(503) 555-3199
3Federal Shipping(503) 555-9931

GROUP BY avec JOIN Exemple

L'instruction SQL suivante répertorie le nombre de commandes envoyées par chaque expéditeur :

Run SQLSELECT Shippers.ShipperName, COUNT(Orders.OrderID) AS NumberOfOrders 
FROM Orders 
LEFT JOIN Shippers 
ON Orders.ShipperID = Shippers.ShipperID 
GROUP BY ShipperName