在SQL Server中更新空XML标记

我正在尝试在sql server上更新我的Xml字符串中的空 XML标记;它表示当我运行以下脚本时更新行,但是当我查看XML时;什么也没有变:
Declare @newValue varchar(100)
select @newValue = '01'

    update dbo.UploadReport
    set XmlTest.insert('replace value of (/CodeFiveReport/Owner/AgencyID/text())[1] with sql:variable("@newValue")') 
    where id = 'myId'

之后仍然在数据库中出现的xml

< AgencyID />

我究竟做错了什么?

我在最后没有文本()的情况下尝试了@AgencyID,仍然无济于事……

解决方法

据我所知,根据我自己的经验,你不能一步到位,因为< AgencyID />元素确实没有text() – 所以,你不能替换它.

您可能必须使用以下内容:

DECLARE @newValue VARCHAR(100)
SELECT @newValue = '01'

-- first update - add a new <AgencyID>...</AgencyID> node    
UPDATE dbo.UploadReport
SET XmlTest.modify('insert <AgencyID>{sql:variable("@newValue")}</AgencyID> as last into (/CodeFiveReport/Owner)[1]') 
WHERE id = 'myId'

-- second update - remove the empty <AgencyID /> node    
UPDATE dbo.UploadReport
SET XmlTest.modify('delete (/CodeFiveReport/Owner/AgencyID)[1]') 
WHERE id = 'myId'

一件事:你需要使用XmlTest.modify操作 – 而不是你的帖子中的XmlTest.insert. SQL Server XML列上没有.insert()函数.

相关文章

本篇内容主要讲解“sqlalchemy的常用数据类型怎么使用”,感...
今天小编给大家分享一下sqlServer实现分页查询的方式有哪些的...
这篇文章主要介绍“sqlmap之osshell怎么使用”,在日常操作中...
本篇内容介绍了“SQL注入的知识点有哪些”的有关知识,在实际...
1. mssql权限sa权限:数据库操作,文件管理,命令执行,注册...
sql执行计划如何查看?在SPL庞大的数据中我们不知道如何查看...