Para uma determinada estrutura como esta:
+----+----------+
| ID | Name |
+----+----------+
| a | ZZZZZZZZ |
| b | YYYYYYYY |
| c | WWWWWWWW |
| d | ZZZZZZZZ |
| e | YYYYYYYY |
| f | WWWWWWWW |
+----+----------+
Obtenha a lista de pares (ID, ID2) com mesmo Nome, excluindo todos os registros onde (ID2, ID) tenha o correspondente (ID, ID2).
+----+----------+-----+
| ID | Name | ID2 |
+----+----------+-----+
| a | ZZZZZZZZ | d |
| b | YYYYYYYY | e |
| c | WWWWWWWW | f |
+----+----------+-----+
Encontrei esta solução, mas gostaria de saber se existe uma solução mais "acadêmica".
;WITH Pair AS
(
SELECT
CASE WHEN p1.Id > p2.Id THEN p2.Id ELSE p1.Id END as ID,
CASE WHEN p1.Id > p2.Id THEN p1.Id ELSE p2.Id END as ID2,
p1.Name
FROM Pairs p1
LEFT JOIN Pairs p2
ON p1.Name = p2.Name
AND p1.Id <> p2.Id
)
SELECT DISTINCT ID, ID2, Name
FROM Pair;
CREATE TABLE Pairs(Id varchar(5), Name varchar(20));
INSERT INTO Pairs VALUES
('a','ZZZZZZZZ'),
('b','YYYYYYYY'),
('c','WWWWWWWW'),
('d','ZZZZZZZZ'),
('e','YYYYYYYY'),
('f','WWWWWWWW');
1 respostas