У меня есть таблица SQL, и я хотел бы создать все комбинации между группами.
Комбинация не будет включена сама по себе
Мой код:
IF OBJECT_ID('tempdb..#tmp_Group_Item') IS NOT NULL
DROP TABLE #tmp_Group_Item
GO
SELECT *
INTO #tmp_Group_Item
FROM (
VALUES
(1, 1)
,(1, 2)
,(1, 3)
,(2, 1)
,(2, 2)
,(3, 1)
,(3, 2)
,(3, 3)
) AS t(GroupID, ID)
Ожидаемый результат будет примерно таким:
CombinationID GroupID ID
------------- ------- --
1 1 1
1 2 1
1 3 1
2 1 1
2 2 1
2 3 2
3 1 1
3 2 1
3 3 3
4 1 2
4 2 1
4 3 1
5 1 2
5 2 1
5 3 2
6 1 2
6 2 1
6 3 3
7 1 3
7 2 1
7 3 1
8 1 3
8 2 1
8 3 2
9 1 3
9 2 1
9 3 3
...
Я пробовал с перекрестным и полным внешним соединением, но не смог этого сделать.