首页 > 解决方案 > Left Join 显示 Table1 和 Table2 中的所有数据

问题描述

我正在尝试进行左连接,以便从表 1 中获取所有行,即使第二个表中没有与之对应的值。

我的结构是:

位置表:

ID     LocName
1      Trk1
2      Trk2
3      Trk3
4      Unk

数量表:

ID    PartID   Quantity LocationID
1     1        2        1
2     3        12       2
3     2        6        1
4     6        8        3
5     6        5        1

我正在尝试加入但也对特定的 PartID 进行查询。我的查询是:

SELECT   
INV_LOCATIONS.ID AS LocationID,  
INV_LOCATIONS.NAME AS LocationName,  
INV_QUANTITY.QUANTITY AS Quantity  
FROM INV_LOCATIONS  
LEFT JOIN INV_QUANTITY ON INV_LOCATIONS.ID = INV_QUANTITY.LOCATION_ID  
WHERE INV_QUANTITY.PART_ID = 1;

我现在的输出是:

ID   LocName   Quantity
1    Trk1      5
3    Trk3      8

期望的输出是:

ID   LocName   Quantity
1       Trk1      5
2       Trk2      NULL/0
3       Trk3      8
4       Unk       NULL/0

我认为这是因为我有WHERE INV_QUANTITY.PART_ID = 1,这迫使它出现在数量表中。我需要能够验证它是否在正确的部分,但如果它不存在,我该如何包含它。我知道我以前做过非常相似的事情,但我不记得是哪个项目,所以我在任何地方都找不到代码。

标签: sqlsql-serverselectleft-join

解决方案


您需要将过滤逻辑移至ON子句:

SELECT il.ID AS LocationID, il.NAME AS LocationName,  
       iq.QUANTITY AS Quantity  
FROM INV_LOCATIONS il LEFT JOIN
     INV_QUANTITY iq
     ON il.ID = iq.LOCATION_ID AND iq.PART_ID = 1;

推荐阅读