基于变量的SQL插入

问题描述 投票:0回答:2

我需要弄清楚如何做以下事情。

我有两列。

一个是交易参考,在我的例子中我是4,5,6的唯一编号。

另一个是分析代码9字段。这只会是A,O或N.

enter image description here

如果在这种情况下不存在Analysis 9代码,则缺少O和A我需要为每个事务引用创建一行 - 这是因为我需要使用它们的组合在SSIS中输出文件,并且客户需要一个空白文件,即使说分析代码O不可用。

所以我希望在这个例子中创建6行。批次4,5,6的O. A批4,5,6。

tsql sql-server-2014
2个回答
0
投票

您基本上想要查找所有不同的事务引用,并将它们与所有可能的代码交叉。然后,您需要对此进行过滤以找出缺失的对。

最后的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]

0
投票

请尝试以下。

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] 

谢谢

© www.soinside.com 2019 - 2024. All rights reserved.