3 つの異なるテーブルに挿入する必要があるストアド プロシージャがありますが、1 つの入力から生成された ID を取得し、それを使用して次のテーブルに挿入する必要があります。私はINSERT-OUTPUT
構造に精通していますが、この特定のケースでそれを使用する方法がわかりません。
DECLARE @guids TABLE ( [GUID] UNIQUEIDENTIFIER );
DECLARE @contacts TABLE ( [ContactID] INT, [GUID] UNIQUEIDENTIFIER );
DECLARE @mappings TABLE ( [TargetID] INT, [GUID] UNIQUEIDENTIFIER );
INSERT @guids ( [GUID] ) ...
INSERT [Contacts] ( [FirstName], [LastName], [ModifiedDate] )
OUTPUT [inserted].[ContactID], g.[GUID]
INTO @contacts
SELECT [First_Name], [Last_Name], GETDATE()
FROM [SourceTable] s
JOIN @guids g ON s.[GUID] = g.[GUID]
INSERT [TargetTable] ( [ContactID], [License], [CreatedDate], [ModifiedDate] )
OUTPUT [inserted].[TargetID], c.[GUID]
INTO @mappings
SELECT c.[ContactID], [License], [CreatedDate], [CreatedDate]
FROM [SourceTable] s
JOIN @contacts c ON s.[GUID] = c.[GUID]
INSERT [Mappings] ( [TargetID], [SourceGUID] )
SELECT [TargetID], [GUID]
FROM @mappings
しかし、次のエラーが発生します。
マルチパート識別子 "g.GUID" をバインドできませんでした。
マルチパート識別子 "c.GUID" をバインドできませんでした。
s.GUID
代わりに使用すると、同様のエラーが発生します。OUTPUT
句で一種の結合を行うことは可能ですか?