我在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还是有更好的方法?应该怎么做?
答案 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>