0

样本数据:

ID1   ID2   Num  Type
---------------------
1     1     1    'A'
1     1     2    'A'
1     2     3    'A'
1     2     4    'A'
2     1     1    'A'
2     2     1    'B'
3     1     1    'A'
3     2     1    'A'

期望的结果:

ID1   ID2
---------
1     1
1     2
3     1
3     2

请注意,我按 ID1 和 ID2 分组,但不是 Num,而且我专门寻找 Type = 'A' 的组。我知道通过在同一个表上连接两个查询是可行的:一个查询查找具有不同类型的所有组,另一个查询过滤 Type = 'A' 的行。但我想知道这是否可以以更有效的方式完成。

我正在使用 SQL Server 2008,我当前的查询是:

SELECT ID1, ID2
FROM (
    SELECT ID1, ID2
    FROM T
    GROUP BY ID1, ID2
    HAVING COUNT( DISTINCT Type ) = 1
) AS SingleType
INNER JOIN (
    SELECT ID1, ID2
    FROM T
    WHERE Type = 'A'
    GROUP BY ID1, ID2
) AS TypeA ON
    TypeA.ID1 = SingleType.ID1 AND
    TypeA.ID2 = SingleType.ID2

编辑:更新了示例数据和查询,以表明我正在对两列进行分组,而不仅仅是一列。

4

2 回答 2

5
SELECT ID1, ID2
FROM MyTable
GROUP BY ID1, ID2
HAVING COUNT(Type) = SUM(CASE WHEN Type = 'A' THEN 1 ELSE 0 END)
于 2012-02-03T16:52:32.293 回答
1

有两种选择不需要聚合(但确实需要不同)

反连接

SELECT DISTINCT t1.ID1, t1.ID2 
FROM
    table  t1
    LEFT JOIN table t2
    ON t1.ID1 = t2.ID1
        and t1.Type <> t2.Type
WHERE
    t1.Type = 'A'
    AND 
    t2.ID1 IS NULL

看到它在这个data.se 查询示例中工作 9132209 (Anti-Join)

不存在

SELECT DISTINCT t1.ID1, t1.ID2 
FROM
    table  t1
WHERE
    t1.Type = 'A'
AND
   NOT EXISTS 
      (SELECT 1 
       FROM table t2 
       WHERE t1.ID1 = t2.ID1 AND Type <> 'A')

请参阅此data.se 查询示例 9132209 不存在

于 2012-02-03T17:44:04.047 回答