首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >删除重复的XML节点SQL查询

删除重复的XML节点SQL查询
EN

Stack Overflow用户
提问于 2021-02-09 15:37:01
回答 1查看 102关注 0票数 1

我有以下XML。

代码语言:javascript
复制
<Root>
  <Child1>
    <SubChild1>some value</PartNumber>
  </Child1>
  <Child2>some data</Child2>
  <Child3>some data</Child3>
  <Child4>some data</Child4>
  <Child2>some data</Child2>
  <Child3>some data</Child3>
  <Child5>some data</Child5>
</Root>

我想删除重复的节点,并以下面的格式返回XML。

代码语言:javascript
复制
<Root>
  <Child1>
    <SubChild1>some value</PartNumber>
  </Child1>
  <Child2>some data</Child2>
  <Child3>some data</Child3>
  <Child4>some data</Child4>
  <Child5>some data</Child5>
</Root>

我尝试了下面的SQL查询,但它不工作。

代码语言:javascript
复制
SELECT @myXMLData.query('
    for $x in distinct-values(//*)[1]
        return
            (//*)[1]
')

我也尝试过distinct-values,但它返回值(没有包含节点属性)。

代码语言:javascript
复制
SELECT @XML.query('<Root>{ distinct-values(//*) }</Root>')

有什么需要帮忙的吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-09 16:09:34

代码语言:javascript
复制
declare @x xml = N'<Root>
  <Child1>
    <SubChild1>some value</SubChild1>
  </Child1>
  <Child2>some data</Child2>
  <Child3>some data</Child3>
  <Child4>some data</Child4>
  <Child2>some data</Child2>
  <Child3>some data</Child3>
  <Child5>some data</Child5>
</Root>';

select node as '*'
from
(
select x.e.query('.') as node, row_number() over(partition by x.e.value('local-name(.)', 'nvarchar(100)') order by x.e) as nodenum
from @x.nodes('Root/*') as x(e)
) as src
where nodenum = 1
for xml path(''), root('Root');
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66114744

复制
相关文章

相似问题

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