在SQL Server中更新空XML标记
发布时间:2020-12-12 06:46:36 所属栏目:MsSql教程 来源:网络整理
导读:我正在尝试在sql server上更新我的Xml字符串中的空 XML标记;它表示当我运行以下脚本时更新行,但是当我查看XML时;什么也没有变: Declare @newValue varchar(100)select @newValue = '01' update dbo.UploadReport set XmlTest.insert('replace value of (/Cod
我正在尝试在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()函数. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |