有几个属性“Num”的xml
DECLARE @XML XML = '
<FileId global_id="1234">
<file id="12aa">
</file>
<file id="12bb">
<Number Num = "1"/>
<Number Num = "2"/>
</file>
</FileId>';
使用此 sql 查询只能获取一个属性
SELECT F.[File].value(N'../@global_id','varchar(100)') as id_payment,
F.[File].value('@id', 'varchar(4)') AS id,
F.[File].value('(Number/@Num)[1]', 'int') as [Num]
FROM (VALUES (@XML)) V (X)
CROSS APPLY V.X.nodes('/FileId/file') F([File])
如何获取所有属性 - Num = 1 和 Num = 2。可以是可变数量的属性。
id_payment id Num
1234 12aa NULL
1234 12bb 1
1234 12bb 2