【问题标题】:How to modify XML node that contains a specific child node value?如何修改包含特定子节点值的 XML 节点?
【发布时间】:2017-10-15 08:58:46
【问题描述】:

我有一个带有 XML 列的表。如何在包含具有特定值的子节点的节点内添加另一个节点?例如,我想将foo/bar/e/f 节点从 barId 6699 复制到 barId 66989。我只找到根据属性值选择节点的示例。我需要按子节点值过滤。

<foo>
    <bar>
        <barId>66988</barId>
        <name>baz 3</name>
    </bar>
    <bar>
        <barId>66989</barId>
        <name>b </name>
        <e>
            <g>
                <h>
                    <l>-</l>
                    <m>k</m>
                </h>
                <h>
                    <l>p  v</l>
                    <m>k</m>
                </h>
            </g>
        </e>
    </bar>
    <bar>
        <barId>6699</barId>
        <name>n 4 c</name>
        <e>
            <f>
                <h>
                    <i>k</i>
                    <j>9.3</j>
                </h>
            </f>
        </e>
    </bar>
</foo>

【问题讨论】:

标签: xml tsql sql-server-2014


【解决方案1】:

试试这个:

DECLARE @value XML = '<foo><bar><barId>66988</barId><name>baz 3</name></bar><bar><barId>66989</barId><name>b </name><e><g><h><l>-</l><m>k</m></h><h><l>p  v</l><m>k</m></h></g></e></bar><bar><barId>6699</barId><name>n 4 c</name><e><f><h><i>k</i><j>9.3</j></h></f></e></bar></foo>';

DECLARE @SourceID INT = 6699;
DECLARE @DestinationID INT = 66989;

DECLARE @temp XML;

SELECT @temp = T.c.query('.')
FROM @value.nodes('/foo/bar[barId = sql:variable("@SourceID")]/e/f') T(c);

SELECT @temp;

SET @value.modify('insert sql:variable("@temp") as last into (/foo/bar[barId =sql:variable("@DestinationID")]/e)[1]')

SELECT @value;

它会给你这个:

<foo>
  <bar>
    <barId>66988</barId>
    <name>baz 3</name>
  </bar>
  <bar>
    <barId>66989</barId>
    <name>b </name>
    <e>
      <g>
        <h>
          <l>-</l>
          <m>k</m>
        </h>
        <h>
          <l>p  v</l>
          <m>k</m>
        </h>
      </g>
      <f>
        <h>
          <i>k</i>
          <j>9.3</j>
        </h>
      </f>
    </e>
  </bar>
  <bar>
    <barId>6699</barId>
    <name>n 4 c</name>
    <e>
      <f>
        <h>
          <i>k</i>
          <j>9.3</j>
        </h>
      </f>
    </e>
  </bar>
</foo>

【讨论】:

    猜你喜欢
    • 2011-09-28
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2023-04-05
    • 2018-07-25
    相关资源
    最近更新 更多