首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL Server XML-DML如何将元素值替换为相对xpath的值

SQL Server XML-DML如何将元素值替换为相对xpath的值
EN

Stack Overflow用户
提问于 2012-01-20 23:13:58
回答 2查看 3K关注 0票数 2

我有一个包含以下数据的xml列:

代码语言:javascript
复制
<Policy>
  <Name>
    <Id>adf</Id>
    <First>Alan</First>
    <Last>Turing</Last>
  </Name>
  <Name>
    <Id>asdf</Id>
    <Business>Vandelay Industries</Business>
  </Name>
  <Name>
    <Id>asdf</Id>
    <First>Dennis</First>
    <Last>Ritchie</Last>
  </Name>
</Policy>

如何编写XML-DML查询来替换所有行中每个名称的Id元素的值,使其包含First、Last和Business的值。例如:

代码语言:javascript
复制
<Policy>
  <Name>
    <Id>AlanTuring</Id>
    <First>Alan</First>
    <Last>Turing</Last>
  </Name>
  <Name>
    <Id>Vandelay Industries</Id>
    <Business>Vandelay Industries</Business>
  </Name>
  <Name>
    <Id>DennisRitchie</Id>
    <First>Dennis</First>
    <Last>Ritchie</Last>
  </Name>
</Policy>

以下是我失败的尝试:

代码语言:javascript
复制
update policy set data.modify('
  replace value of (//Name/Id/text())[1] 
  with concat(
    (//Name/First/text())[1], 
    (//Name/Last/text())[1], 
    (//Name/Business/text())[1])') 

这会产生以下结果:

代码语言:javascript
复制
<Policy>
  <Name>
    <Id>AlanTuringVandelay Industries</Id>
    <First>Alan</First>
    <Last>Turing</Last>
  </Name>
  <Name>
    <Id>asdf</Id>
    <Business>Vandelay Industries</Business>
  </Name>
  <Name>
    <Id>asdf</Id>
    <First>Dennis</First>
    <Last>Ritchie</Last>
  </Name>
</Policy>
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-01-20 23:54:27

这是可行的。

代码语言:javascript
复制
declare @i int
declare @maxNames int
set @i = 1
set @maxNames = (select max(data.value('count(//Name)', 'int')) from Policy)
while @i <= @maxNames begin
    update policy set data.modify('
      replace value of (//Name[sql:variable("@i")]/Id/text())[1] 
      with concat(
        (//Name[sql:variable("@i")]/First/text())[1], 
        (//Name[sql:variable("@i")]/Last/text())[1], 
        (//Name[sql:variable("@i")]/Business/text())[1])
    ') 
    set @i = @i + 1
end
票数 3
EN

Stack Overflow用户

发布于 2015-11-24 06:43:09

基于集合的选项如下所示:

代码语言:javascript
复制
    update policy 
    set data.modify('
    replace value of (//Name[sql:column("id")]/Id/text())[1]
    with concat(
    (//Name[sql:column("id")]/First/text())[1],
    (//Name[sql:column("id")]/Last/text())[1],
    (//Name[sql:column("id")]/Business/text())[1])
    ') 
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8943553

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档