我有一个接受 xml 作为输入的查询。如何返回插入期间创建的所有 ID?
insert into Table1
(
FirstName, Age
)
SELECT
T.item.query('./FirstName').value('.', 'varchar(54)') FirstName,
T.item.query('./Age').value('.', 'int') Age,
FROM @Collection.nodes('/ROWS/ROW') AS T(Item)
我不确定返回新 ID 的最佳方式。
最佳答案
使用OUTPUT clause .
DECLARE @InsertedIDs table(ID int);
INSERT INTO Table1
(FirstName, Age)
OUTPUT INSERTED.ID
INTO @InsertedIDs
SELECT
T.item.query('./FirstName').value('.', 'varchar(54)') FirstName,
T.item.query('./Age').value('.', 'int') Age,
FROM @Collection.nodes('/ROWS/ROW') AS T(Item);
SELECT ID FROM @InsertedIDs;
关于xml - 使用 xml 输入获取多个插入行的 ID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6711978/