在我的数据库表中,我有一列,其中整个条目是一个具有以下结构的长XML字符串:
<Group1>
<Title>
<Name>John Doe</Name>
<Phone>555-3421</Phone>
<Email>catman@gmail.com</Email>
(+more)
</Title>
</Group1>
这是我的SELECT语句,以下是它的输出结果:
SELECT TheKey, TheData FROM MyTable;
在SQL Server Management Studio中的输出:
TheKey TheData
10000 <Group1><Title><Name>John Doe</Name><Phone>893-3421</Phone><Email>catman@gmail.com</Email></Title></Group1>
10001 <Group1><Title><Name>Mary Sue</Name><Phone>381-2342</Phone><Email>thebestdude@gmail.com</Email></Title></Group1>
10002 <Group1><Title><Name>Mark Dark</Name><Phone>312-7626</Phone><Email>mybook231@gmail.com</Email></Title></Group1>
10003 <Group1><Title><Name>Garth Dan</Name><Phone>341-4572</Phone><Email>lampshade032@gmail.com</Email><State>California</State></Title></Group1>
我想编写一种 MS SQL 查询,可以像这样为我返回数据:
TheKey Name Phone Email State
10000 John Doe 893-3421 catman@gmail.com NULL
10001 Mary Sue 381-2342 thebestdude@gmail.com NULL
10002 Mark Dark 312-7626 mybook231@gmail.com NULL
10003 Garth Dan 341-4572 lampshade032@gmail.com California
注意:最后一条记录有一个额外的XML标签<State>
,而其他记录没有。我希望它可以灵活地使用一些父/子引用来实现这一点。
如果能得到任何帮助,我将不胜感激,因为我似乎找不到任何类似的东西=)