sql-server - 在 SQL Server 中解析 XML

标签 sql-server xml sql-server-2005

XML 看起来像这样:

<GespeicherteDaten>
    <strategieWuerfelFelder Type="strategieWuerfelFelder">
        <Felder X="3" Y="3" Z="3">
            <Feld X="1" Y="1" Z="1">
                <strategieWuerfelFeld Type="strategieWuerfelFeld">
                    <Name>Name</Name>
                    <Beschreibung>Test</Beschreibung>
                </strategieWuerfelFeld>
            </Feld>
            <Feld X="1" Y="1" Z="2">
                <strategieWuerfelFeld Type="strategieWuerfelFeld">
                    <Name>Name2</Name>
                    <Beschreibung>Test2</Beschreibung>
                </strategieWuerfelFeld>
            </Feld>
        </Felder>
    </strategieWuerfelFelder>
</GespeicherteDaten>'

我的结果表应该包含属性 Felder->X, Y, Z, Feld->X,Y,Z 和 Name。

喜欢:

Felder_X | Felder_Y | Felder_Z | Feld_X | Feld_Y | Feld_Z | Name

是否可以直接从查询或存储过程中获取这些值?

最佳答案

DECLARE @xml xml
SET @xml = 
'<GespeicherteDaten>
<strategieWuerfelFelder Type="strategieWuerfelFelder">
    <Felder X="3" Y="3" Z="3">
        <Feld X="1" Y="1" Z="1">
            <strategieWuerfelFeld Type="strategieWuerfelFeld">
                <Name>Name</Name>
                <Beschreibung>Test</Beschreibung>
            </strategieWuerfelFeld>
        </Feld>
        <Feld X="1" Y="1" Z="2">
            <strategieWuerfelFeld Type="strategieWuerfelFeld">
                <Name>Name2</Name>
                <Beschreibung>Test2</Beschreibung>
            </strategieWuerfelFeld>
        </Feld>
    </Felder>
</strategieWuerfelFelder></GespeicherteDaten>'

SELECT 
    b.value('@X', 'int') as X
  , b.value('@Y', 'int') as Y
  , b.value('@Z', 'int') as Z
  , b.value('(./strategieWuerfelFeld/Name/text())[1]','Varchar(50)') as [Name]
  , b.value('../@X','int') as Felder_X
  , b.value('../@Y','int') as Felder_Y
  , b.value('../@Z','int') as Felder_Z  
FROM @xml.nodes('/GespeicherteDaten/strategieWuerfelFelder/Felder/Feld') as a(b) 

关于sql-server - 在 SQL Server 中解析 XML,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15680259/

相关文章:

sql-server - SQL Server 文件版本号 : where can I find a reference?

sql-server - PySpark 1.5 和 MSSQL jdbc

php - 匹配出现在 XML 节点内的 ">"、 "<"、 "&"字符的正则表达式

HTML - XML 数据孤岛

performance - 计算列索引

SQL获取日期列表以及之前和之后的天数而不重复

sql-server - SQL Server 数据库最大行 RowVersion

sql - 根据变量类型在 SQL 中进行条件分支

xml - XML Schema 是 SGML DTD 的子集吗?

sql-server-2005 - 如何在不声明表的情况下选择 * INTO [临时表]?