如何使用TSQL向现有的根XML节点添加属性?

时间:2016-08-31 13:05:14

标签: sql-server xml tsql

我在TSQL中构建了一些XML。

declare @requestXML xml

set @requestXML = (
select @dataXML
for xml raw ('rtEvent') 

我现在拥有的一般输出遵循类似的模式:

<rtEvent>
  <ctx>
    .....
  </ctx>
</rtEvent>

我现在要做的是向rtEvent根添加一些属性和值 元素节点,但我不确定如何实现它。

我已经查看了XML对象的Modify方法,并观察了插入,替换值和删除操作,但似乎无法弄清楚如何使用它们中的任何一个来实现结果I&#39;之后。

基本上,我希望能够修改根节点以反映类似的内容:

<rtEvent type="customType" email="someaddress@domain.com"
  origin="eCommerce" wishedChannel="0" externalId="5515">
   <ctx>
     ...
   </ctx>
</rtEvent>

我应该使用文档化的XML.Modify还是有更好的方法?应该怎么做?

2 个答案:

答案 0 :(得分:4)

更好地使用FOR XML PATH,它允许您根据需要指定命名和别名:

SELECT 'SomeContext' AS [ctx]
FOR XML PATH('rtEvent')

这将返回:

<rtEvent>
  <ctx>SomeContext</ctx>
</rtEvent>

但是如果有正确的属性,你就会得到这个:

SELECT  'customType' AS [@type]
       ,'someaddress@domain.com' AS [@email]
       ,'eCommerce' AS [@origin]
       ,0 AS [@wishedChannel]
       ,5515 AS [@externalId]
       ,'SomeContext' AS [ctx]
FOR XML PATH('rtEvent')

结果

<rtEvent type="customType" email="someaddress@domain.com" origin="eCommerce" wishedChannel="0" externalId="5515">
  <ctx>SomeContext</ctx>
</rtEvent>

答案 1 :(得分:2)

以防万一你想看到修改方法的方法:

DECLARE @requestXML XML = '<rtEvent><ctx>...</ctx></rtEvent>'
SET @requestXML.modify(
    'insert 
    (
        attribute type {"customeType"},
        attribute email {"someaddress@domain.com"},
        attribute origin {"eCommerce"},
        attribute wishedChannel {"0"},
        attribute externalId {"5515"}
    )
    into (/rtEvent)[1]')
SELECT @requestXML

它返回:

<rtEvent type="customeType" email="someaddress@domain.com" origin="eCommerce" wishedChannel="0" externalId="5515">
  <ctx>...</ctx>
</rtEvent>