题
我的SQL Server 2008数据库中有XML列。 XML在我表的每一行中样本
<document>
<part1>
<listitem>val1</listitem>
<listitem>val2</listitem>
<listitem>val3</listitem>
</part1>
<part2>
<listitem>val4</listitem>
</part2>
</document>
我想从所有行中选择所有元素。从上面的示例中,我应该获得具有ListItem值的四行。
答案是
select x.nd.value ('(.)[1]', 'varchar(250)') as ValuesFromXml
from TableWithXmlColumn t cross apply t.XmlContent.nodes (
'//listitem') x(nd);
感谢帮助
解决方案
您可以这样做:
select Col.value('.', 'varchar(20)')
from yourtable
cross apply XmlColumn.nodes('//listitem') as NewTable(Col)
不隶属于 StackOverflow