我正在处理一个简单的插入语句。此查询插入核心记录,返回ID,然后将一个或多个任务插入另一个表。对于每个任务,我需要在第3个表中进行额外的插入。
由于第二次插入语句发生在第3次之前,我在尝试弄清楚如何设置它时遇到了一些麻烦,因此我不确定如何从每个插入的identity
传递给查询3。
DECLARE @requestID INT;
-- Insert the core request details
INSERT INTO esas.Request (Requestor, Justification, CreatedBy, DateCreated)
SELECT @requestor,
@justification,
@creator,
GETUTCDATE()
-- Define the core request ID
SET @requestID = SCOPE_IDENTITY();
-- Add tasks
INSERT INTO esas.Task
( RequestID ,
ToolID ,
QID ,
Action
)
SELECT @requestID,
ParamValues.x1.value('tool[1]', 'INT'),
ParamValues.x1.value('user[1]', 'VARCHAR(10)'),
ParamValues.x1.value('action[1]', 'INT)')
FROM @tasks.nodes('/request/task') AS ParamValues(x1);
-- For each task, add any associated roles (stuck here)
INSERT INTO esas.TaskRoles
( TaskID,
RoleID,
ActionID )
VALUES ( 0, -- TaskID - int
0, -- RoleID - int
0 -- ActionID - int
)
在最后一次插入中,我需要传递PK/AI
{"创建的TaskID
添加任务"到另一个表,以及XML字符串中的roleID
和action
。
这是我的XML结构:
<request>
<task>
<tool>123</tool>
<user>4567</user>
<roles>
<role>
<roleID>12</roleID>
<action>1</action>
</role>
<role>
<roleID>1245</roleID>
<action>0</action>
</role>
<role>
<roleID>678</roleID>
<action>1</action>
</role>
</roles>
</task>
</request>
我的困惑是因为我知道INSERT INTO esas.Task
将会一直发生,然后继续前进,所以我不确定如何将每个身份传递给下一个插入以及XML结构中的相应细节。
答案 0 :(得分:1)
我在使用xpath并在插入数据后加入tasks
表时想出来了。
-- For each task, add any associated roles
INSERT INTO esas.TaskRoles
( TaskID,
RoleID,
ActionID )
SELECT t.TaskID,
ParamValues.x1.value('roleID[1]', 'INT'),
ParamValues.x1.value('action[1]', 'INT')
FROM esas.Task AS t
JOIN @tasks.nodes('/request/task/roles/role') AS ParamValues(x1)
ON t.RequestID = @requestID
AND t.ToolID = ParamValues.x1.value('../../tool[1]', 'INT')
AND t.QID = ParamValues.x1.value('../../user[1]', 'VARCHAR(10)')