0

我有下面提到的表(id 和 Loc 是主键)

ID LOC RNK NBR1 NBR2
1 2 A 10 b --->
3 4 A 10 b --->
5 6 A 11 C
8 2 A 12 D
6 3 A 10 b --->

所以在这里我必须根据 NBR1 和 NBR2 仅获取重复记录,它应该获取所有记录,而不仅仅是重复项(标记为 --->)。

4

2 回答 2

0

如果我正确理解了您的问题,您可以使用子查询来完成

CREATE TABLE #Test (ID int, LOC int, RNK char(1), NBR1 int, NBR2 char(1) )

INSERT INTO #Test VALUES
    (1, 2, 'A', 10, 'b'),
    (3, 4, 'A', 10, 'b'),
    (5, 6, 'A', 11, 'C'),
    (8, 2, 'A', 12, 'D'),
    (6, 3, 'A', 10, 'b')

SELECT *
FROM #Test t1
WHERE EXISTS
    (SELECT 1
     FROM #Test t2
     WHERE t1.NBR1 = t2.NBR1
       AND t1.NBR2 = t2.NBR2
     GROUP BY NBR1, NBR2
     HAVING COUNT(1) > 1)
于 2013-03-14T20:31:20.160 回答
0

您也可以使用它,但成本会更高。值大于 1 的 RowsCount 是重复的,值为 1 是唯一记录。

With Temp As
(
    Select ID,LOC,RNK,NBR1,NBR2,Row_NUMBER() OVER (PARTITION BY NBR2 ORDER BY NBR1) AS ROWSCOUNT FROM <<TABLE_NAME>>
)

Select * from Temp
于 2013-05-06T11:30:46.283 回答