选择XML的父级和子级值

8

尝试从XML中同时检索父项和子项值时遇到问题。代码如下,但只能检索每个父项的1个子项。如何选择具有父项的所有子项?


declare @x xml;

set @x = '
    <Parent ParentID="1" ParentName="Mary">
        <Child ChildID="2" ChildName="Paul" />
        <Child ChildID="3" ChildName="Alan" />
        <Child ChildID="4" ChildName="David" />
    </Parent>
    <Parent ParentID="5" ParentName="James">
        <Child ChildID="6" ChildName="Amy" />
        <Child ChildID="7" ChildName="Julie" />
    </Parent>
';

select 
tbl.col.value('@ParentID', 'int') AS ParentID,
tbl.col.value('@ParentName', 'varchar(50)') AS ParentName,
tbl.col.value('Child[1]/@ChildID[1]', 'int') AS ChildID,
tbl.col.value('Child[1]/@ChildName[1]', 'varchar(50)') AS ChildName
from @x.nodes('/Parent') as tbl(col);

我得到了以下结果,但希望父节点针对每个子节点都重复。

ParentID   ParentName   ChildID  ChildName
1          Mary         2        Paul
5          James        6        Amy

问题是Child[1],但我不知道该如何解决。我尝试了sql-variable,但也无法解决问题。理想情况下,我希望看到以下结果:

ParentID   ParentName   ChildID  ChildName
1          Mary         2        Paul
1          Mary         3        Alan
1          Mary         4        David
5          James        6        Amy
5          James        7        Julie

任何帮助都将不胜感激。谢谢。
2个回答

7
select 
tbl.col.value('parent::*/@ParentID', 'int') AS ParentID,
tbl.col.value('parent::*/@ParentName', 'varchar(50)') AS ParentName,
tbl.col.value('@ChildID', 'int') AS ChildID,
tbl.col.value('@ChildName', 'varchar(50)') AS ChildName
from @x.nodes('/Parent/Child') as tbl(col);

0

尝试以下代码:

    select 
    tbl.col.value('@ParentID', 'int') AS ParentID,
    tbl.col.value('@ParentName', 'varchar(50)') AS ParentName,
    p.j.value('@ChildID[1]', 'int') AS ChildID,
    p.j.value('@ChildName[1]', 'varchar(50)') AS ChildName
    from @x.nodes('/Parent') as tbl(col)
    cross apply tbl.col.nodes('Child') as p(j)

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接