2

下午好,

我想通过使用 TSQL 变量来删除 XML 属性。这是一个最低限度的工作示例(TSQL 代码):

DECLARE @xml XML;
SET @xml = CONVERT(XML, N'
<recipe>
    <parameters>
        <parameter name="a" desc="A">ValueA</parameter>
        <parameter name="b" desc="B">ValueB</parameter>
        <parameter name="c" desc="C">ValueC</parameter>
    </parameters>
</recipe>
');
SET @xml.[modify]('delete (/recipe/parameters/parameter/@desc)');
SELECT  @xml;

这给出了所需的输出:所有属性“desc”已被删除:

<recipe>
  <parameters>
    <parameter name="a">ValueA</parameter>
    <parameter name="b">ValueB</parameter>
    <parameter name="c">ValueC</parameter>
  </parameters>
</recipe>

但是,我想定义一个 TSQL 变量

DECLARE @attr NVARCHAR(MAX) = N'desc';

如何将它传递给 XQuery 修改操作?我可以在 XML DML 中使用sql:variable("@attr"),但是如何使用它来处理属性?

谢谢你的帮助!

4

1 回答 1

4

您可以在指定属性时使用通配符,然后检查谓词中的属性名称。

SET @xml.[modify](
  'delete(/recipe/parameters/parameter/@*[local-name() = sql:variable("@attr")])');
于 2016-06-09T14:28:11.600 回答