SQL外连接,具有引用同一个表的多个外键

时间:2015-04-17 01:28:07

标签: sql outer-join jointable

我有一张

的表格
P1   P2   P3   P4   P5
ID   ID   NULL ID   NULL
...

和一个带

的表格
ID   Name
ID   xyz
...

并希望选择此节目,例如:

P1   P2   P3   P4   P5
Name Name Name Name Name
...

我尝试使用Join(一个和多个),Select和Multiple FROM,但每次我拥有ID为5列的所有5列,每列都包含每个名称。

现在我正在考虑制作一个新表,并将每一列都放在那里,但我想并希望还有另一种方法。

编辑: 我的代码:

    SELECT 
    TodayPaddock.Paddock1, 
    TodayPaddock.Paddock2
FROM 
    TodayPaddock
Left OUTER JOIN 
Pferde ON Pferde.Id = TodayPaddock.Paddock1  
AND Pferde.Id = TodayPaddock.Paddock2

2 个答案:

答案 0 :(得分:0)

您需要多个join。事实上left join s:

select t2_1.name, t2_2.name, t2_3.name, t2_4.name, t2_5.name
from table1 t1 left join
     table2 t2_1
     on t1.p1 = t2_1.id left join
     table2 t2_2
     on t1.p2 = t2_2.id left join
     table2 t2_3
     on t1.p3 = t2_3.id left join
     table2 t2_4
     on t1.p4 = t2_4.id left join
     table2 t2_5
     on t1.p5 = t2_5.id;

答案 1 :(得分:0)

有一种方法可以使用单个外部联接。当然,您需要检查查询计划,以确保它在调整索引后以及足够数量的数据时比5个联接的查询计划更好。此解决方案假定P1,P2,P3,P4,P5是TodayPaddock表的唯一键。如果没有,您将需要添加一个唯一列进行分组,即使它只是一个自动增量列。

CREATE TABLE Pferde (
    ID INT NOT NULL PRIMARY KEY,
    Name VARCHAR(50) NOT NULL
)

INSERT Pferde (ID, Name) VALUES (1, 'NAME1')
INSERT Pferde (ID, Name) VALUES (2, 'NAME2')
INSERT Pferde (ID, Name) VALUES (3, 'NAME3')
INSERT Pferde (ID, Name) VALUES (4, 'NAME4')
INSERT Pferde (ID, Name) VALUES (5, 'NAME5')

CREATE TABLE TodayPaddock (
    P1 INT NULL FOREIGN KEY REFERENCES Pferde,
    P2 INT NULL FOREIGN KEY REFERENCES Pferde,
    P3 INT NULL FOREIGN KEY REFERENCES Pferde,
    P4 INT NULL FOREIGN KEY REFERENCES Pferde,
    P5 INT NULL FOREIGN KEY REFERENCES Pferde,
    UNIQUE (P1, P2, P3, P4, P5)
)

INSERT TodayPaddock (P1, P2, P3, P4, P5) VALUES (1, 2, NULL, 4, NULL)
INSERT TodayPaddock (P1, P2, P3, P4, P5) VALUES (NULL, NULL, 3, NULL, 5)

SELECT
    MAX(CASE WHEN P.ID = TP.P1 THEN P.Name END) AS P1,
    MAX(CASE WHEN P.ID = TP.P2 THEN P.Name END) AS P2,
    MAX(CASE WHEN P.ID = TP.P3 THEN P.Name END) AS P3,
    MAX(CASE WHEN P.ID = TP.P4 THEN P.Name END) AS P4,
    MAX(CASE WHEN P.ID = TP.P5 THEN P.Name END) AS P5
FROM TodayPaddock AS TP
LEFT JOIN Pferde AS P
ON P.ID IN (TP.P1, TP.P2, TP.P3, TP.P4, TP.P5)
GROUP BY TP.P1, TP.P2, TP.P3, TP.P4, TP.P5

结果:

P1      P2      P3      P4      P5
NULL    NULL    NAME3   NULL    NAME5
NAME1   NAME2   NULL    NAME4   NULL