Skip to content

SQL自连接


自联接是一种常规联接,但表本身是连接的。

Self JOIN语法

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

演示数据库


在本教程中,我们将使用着名的Northwind示例数据库。

以下是"Customers"表中的选择:

CustomerIDCustomerNameContactNameAddressCityPostalCodeCountry
1Alfreds FutterkisteMaria AndersObere Str. 57Berlin12209Germany
2Ana Trujillo Emparedados y heladosAna TrujilloAvda. de la Constitución 2222México D.F.05021Mexico
3Antonio Moreno TaqueríaAntonio MorenoMataderos 2312México D.F.05023Mexico

SQL Self JOIN示例


以下SQL语句匹配来自同一城市的客户:

代码示例

sql
SELECT 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;