我需要弄清楚如何做以下事情。
我有两列。
一个是交易参考,在我的例子中我是4,5,6的唯一编号。
另一个是分析代码9字段。这只会是A,O或N.
如果在这种情况下不存在Analysis 9代码,则缺少O和A我需要为每个事务引用创建一行 - 这是因为我需要使用它们的组合在SSIS中输出文件,并且客户需要一个空白文件,即使说分析代码O不可用。
所以我希望在这个例子中创建6行。批次4,5,6的O. A批4,5,6。
您基本上想要查找所有不同的事务引用,并将它们与所有可能的代码交叉。然后,您需要对此进行过滤以找出缺失的对。
最后的LEFT JOIN将为您进行过滤。
CREATE TABLE [#trans]
(
[Transaction Reference] int,
[Analysis 9 Code] char(1)
)
CREATE TABLE [#codes]
(
[Code] char(1)
)
-- Create a table with all potential code values
INSERT INTO [#codes] ([Code]) VALUES ('A')
INSERT INTO [#codes] ([Code]) VALUES ('N')
INSERT INTO [#codes] ([Code]) VALUES ('O')
-- Insert your dummy data
INSERT INTO [#trans] ([Transaction Reference], [Analysis 9 Code]) VALUES (6, 'N')
INSERT INTO [#trans] ([Transaction Reference], [Analysis 9 Code]) VALUES (6, 'N')
INSERT INTO [#trans] ([Transaction Reference], [Analysis 9 Code]) VALUES (4, 'N')
INSERT INTO [#trans] ([Transaction Reference], [Analysis 9 Code]) VALUES (4, 'N')
INSERT INTO [#trans] ([Transaction Reference], [Analysis 9 Code]) VALUES (5, 'N')
INSERT INTO [#trans] ([Transaction Reference], [Analysis 9 Code]) VALUES (6, 'N')
SELECT [ExistingRefs].[Transaction Reference] AS [Transaction Reference],
[#codes].[Code] AS [Analysis 9 Code]
FROM
(
SELECT DISTINCT([Transaction Reference]) [Transaction Reference] FROM [#trans]
) [ExistingRefs]
CROSS JOIN [#codes]
LEFT JOIN [#trans] ON [ExistingRefs].[Transaction Reference] = [#trans].[Transaction Reference]
AND [#codes].[Code] = [#trans].[Analysis 9 Code]
WHERE [#trans].[Analysis 9 Code] IS NULL
DROP TABLE [#trans]
DROP TABLE [#codes]
请尝试以下。
select distinct t.[Transaction Reference],x.code from #trans t
cross apply(select distinct code from #codes c inner join #trans tt on c.Code<>tt.[Analysis 9 Code])x
order by t.[Transaction Reference]
谢谢