使用xml输入获取多个插入行的ID

时间:2011-07-15 19:05:28

标签: xml sql-server-2005 stored-procedures

我有一个接受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的最佳方式。

1 个答案:

答案 0 :(得分:4)

使用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;