SQL:Looping 和从 XML 类型读取

SQL:Looping and Reading from XML type

我有一组来自 XML 类型的记录,我需要遍历节点并从中提取数据

<Data xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
      <OP xmlns="http://tempuri.org/Types.xsd">
        <ID>
          <FDSerial>00000008</FDSerial>
          <Type>1</Type>
        </ID>
        <Param>1</Param>
        <OperationName>ReadData</OperationName>
      </OP>
      <OP xmlns="http://tempuri.org/Types.xsd">
        <ID>
          <FDSerial>00000009</FDSerial>
          <Type>1</Type>
        </ID>
        <Param>1</Param>
        <OperationName>ReadData</OperationName>
      </OP>
    </Data>

我已经从记录中读取,但我需要遍历节点

    ;WITH XMLNAMESPACES('http://tempuri.org/Types.xsd' as ns) 
SELECT  Data.value('/Data[1]/ns:Op[1]/ns:ID[1]/ns:FDSerial[1]', 'varchar(50)')
        as Serial   
  FROM [dbo].[DB]

我需要在循环中用 i 替换 #1

更新: 我更新了 xml 数据。

此数据的预期值是 FDSerial 的节点值。 我希望我清楚地解释了我的问题

你根本不需要循环。在 /Data/OP.

交叉应用中使用 nodes() 切碎
with xmlnamespaces('http://tempuri.org/Types.xsd' as ns)
select T.X.value('(ns:ID/ns:FDSerial/text())[1]', 'varchar(50)') as Serial
from dbo.DB
  cross apply DB.Data.nodes('/Data/ns:OP') as T(X)

这也行

;WITH XMLNAMESPACES('http://tempuri.org/Types.xsd' as ns) 
SELECT  Data.value('(Data/ns:Op/ns:ID/ns:FDSerial/text())[1]', 'varchar(50)')
        as Serial   
  FROM [dbo].[DB]