TOP

SQL Self Join (auto-jointure)

SQL Self Join descriptif

Une auto-jointure est une jointure régulière dans laquelle une table est jointe à elle-même.


Self Join Syntaxe

SELECT column_name(s)
FROM table1 T1, table1 T2
WHERE condition

T1 et T2 sont des alias différents pour la même table.

Base de données de démonstration

Dans ce tutoriel nous utiliserons la célèbre base de données exemple "Northwind".

Vous trouverez ci-dessous un exemple de la table "Customers" ("Clients").

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 Self Join Exemple

L'instruction SQL suivante sélectionne les clients d'une ville (City) :

Run SQLSELECT A.CustomerName AS CustomerName1, B.CustomerName AS CustomerName2, A.City 
FROM Customers A, Customers B 
WHERE A.CustomerID <> B.CustomerID 
AND A.City = B.City 
ORDER BY A.City
Le dialecte MySQL utilise "!=" au lieu de "<>".