SQL基于嵌套xpath插入数据

问题描述 投票:1回答:1

我有一个简单的插入语句,我正在努力。此查询插入核心记录,返回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字符串中的roleIDaction

这是我的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结构中的相应细节。

sql-server xml xpath sql-server-2012
1个回答
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)')
© www.soinside.com 2019 - 2024. All rights reserved.