SQL Server:如何在查询中获取XML属性?

18

我目前正在尝试使用SQL查询从XML中获取所有属性。

我一直在尝试以下代码来检索它,但我必须漏掉了某些根本的东西。

DECLARE @T varchar(max) 
SET @T = 
'<root>
    <Field FieldRowId="1000">
    <Items>
        <Item Name="CODE"/>
        <Item Name="DATE"/>
    </Items>
        <Attributes>
        <Attribute ID ="1"/>
        </Attributes>
    </Field>
    <Field FieldRowId="2000">
    <Items>
                <Item Name="CODE"/>
                <Item Name="DATE"/>
    </Items>
    <Attributes>
        <Attribute ID ="2"/>
    </Attributes>
    </Field>
</root>'

DECLARE @X xml

SET @X = CAST(@T as xml)
SELECT Y.ID.value('@FieldRowId', 'int') as FieldID, 
   Y.ID.value('/Items/@Name', 'varchar(max)') as "Name",
   Y.ID.value('/Attributes/@ID', 'int') as AttributeID
FROM @X.nodes('/root/Field') as Y(ID)
2个回答

48
您需要尝试类似以下这样的代码:(@name 属性在 "Item" 元素上,而不是 "Items"!)
SET @X = CAST(@T as xml)
SELECT 
   Y.ID.value('(@FieldRowId)[1]', 'int') as FieldID,
   Y.ID.value('(Items/Item/@Name)[1]', 'varchar(max)') as "Name",
   Y.ID.value('(Attributes/Attribute/@ID)[1]', 'int') as AttributeID
FROM @X.nodes('/root/Field') as Y(ID)

马克


1
SELECT t1.fieldId, name, attributeId
FROM ( SELECT Y.ID.value('../../@FieldRowId', 'int') as FieldID
     , Y.ID.value('@Name', 'varchar(max)') as Name    
FROM @T.nodes('(/root/Field/Items/Item)') as Y(ID)
) t1 -- alias the first result 
JOIN
(SELECT Y.ID.value('../../@FieldRowId', 'int') as FieldID
    , Y.ID.value('@ID', 'int') as AttributeID
FROM @T.nodes('(/root/Field/Attributes/Attribute)') as Y(ID)
) t2 -- alias the second result 
on t1.fieldid = t2.FieldID -- join them on a common column

1
这是你的答案。请注意,在 SQL 中有一种 XML 类型,因此您不需要使用 varchar 然后转换为 xml。 - Sergio Guerrero
如果需要Field元素内的所有数据,则此答案更正确。 - Serg

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