Допустим, у меня есть таблица #Foo:
Id Color
-- ----
1 Red
2 Green
3 Blue
4 NULL
И стол #Бар:
Value
-----
1
2.5
Я хотел бы создать таблицу Result, используя простой оператор, чтобы получить:
Id Color Value
-- ---- -----
1 Red 1
2 Green 2.5
3 Blue NULL
4 NULL NULL
То, что я изобрел до сих пор, это:
WITH cte1
AS
(
SELECT [Id], [Color], ROW_NUMBER() OVER (ORDER BY [Id]) AS 'No'
FROM #Foo
),
cte2
AS
(
SELECT [Value], ROW_NUMBER() OVER (ORDER BY [Value]) AS 'No'
FROM #Bar
)
SELECT [Id], [Color], [Value]
FROM cte1 c1
FULL OUTER JOIN cte2 c2 ON c1.[No] = c2.[No]
Знаете ли вы более быстрый или более стандартный способ сделать ZIP JOIN в T-SQL?