从sql server中的多个LEFT JOIN中删除NULL值

时间:2012-05-14 06:18:27

标签: sql sql-server-2005

我有以下表格

ITEM1

ID | NAME | GEARS | ITEM2_ID  |
-------------------------------
1  | Test | 56    | 4         |
2  | Test2| 12    | 2         |

ITEM3

ID | NAME | DATA  | ITEM2_ID  |
-------------------------------
1  | Test | 1     | 1         |
2  | Test7| 22    | 3         |

ITEM2

ID |   VALUE       |
--------------------
1  |   is simple   |  
2  |   is hard     | 
3  |   is different|
4  |   is good     |
5  |   very good   |

我的查询

SELECT TOP(3) * FROM (
    SELECT ID, 
       rankTable.RANK as RANK_,
        TOTALROWS = COUNT(*) OVER() 
 FROM ITEM2
 INNER JOIN 
     CONTAINSTABLE(ITEM2, [VALUE], 'ISABOUT("good")') as rankTable
 ON ITEM2.ID = rankTable.[KEY]
) as ITEM2table

LEFT JOIN (
    SELECT ID, 
      NAME, 
      GEARS, 
      ITEM2_ID 
    FROM ITEM1
) as ITEM1table
ON ITEM1table.ITEM2_ID = ITEM2table.ID

LEFT JOIN (
    SELECT ID, 
        NAME, 
        DATA, 
        ITEM2_ID 
    FROM ITEM3
) as ITEM3table
ON ITEM3table.ITEM2_ID = ITEM2table.ID

和结果

enter image description here

如何使用上面的SQL查询删除(如果可能)第一行(ID = 5)?另外我想显示TOTALROWS = 1,因为除了前3列之外,其他行包含NULL。

谢谢。

3 个答案:

答案 0 :(得分:3)

也许有一个明显的原因,但是如果你想消除第二个表没有匹配的行,你为什么要使用左连接?看起来你的第一个连接应该是一个内部连接,而你的第二个应该是左边的 - 这将为你提供你想要的结果。

答案 1 :(得分:3)

如果我理解正确,您只想保留第一个或第二个(或两个)外部联接成功的行:

WHERE ITEM1table.ITEM2_ID IS NOT NULL 
   OR ITEM3table.ITEM2_ID IS NOT NULL 

可以对查询进行一些简化。不需要嵌套子查询:

SELECT TOP(3) 
    ITEM2table.ID, 
    rankTable.RANK as RANK_,
    TOTALROWS = COUNT(*) OVER(),
    ITEM1table.*,
    ITEM3table.*  

FROM 
        ITEM2 

    INNER JOIN 
        CONTAINSTABLE(ITEM2, [VALUE], 'ISABOUT("good")') as rankTable
    ON ITEM2.ID = rankTable.[KEY]

    LEFT JOIN 
        ITEM1  as ITEM1table
    ON ITEM1table.ITEM2_ID = ITEM2.ID

    LEFT JOIN 
        ITEM3  as ITEM3table
    ON ITEM3table.ITEM2_ID = ITEM2.ID

WHERE ITEM1table.ITEM2_ID IS NOT NULL 
   OR ITEM3table.ITEM2_ID IS NOT NULL 

ORDER BY  something                     --- you need to order by something
                                        --- if you use TOP. Unless you want 
                                        --- 3 (random) rows.

答案 2 :(得分:0)

您可以使用INNER JOIN代替LEFT JOIN,也可以使用

WHERE ITEM1table.ID IS NOT NULL AND ITEM3table.ID IS NOT NULL
在您的查询结尾处