解析列中的 XML 数据

Parsing the XML Data in columns

需要帮助来解析下面的 XML 列、语言和值基础。我能够以行为基础解析值。任何人都可以帮忙。查询需要在SQL服务器中。我试过使用 OPENXML 写作。但它没有给我想要的输出。任何帮助将不胜感激。

<Root>
  <dataModel>
    <repo name="SKU" profile="SKU"/>
  </dataModel>
  <SKU repo="SKU">   
    <SKU_SKU_Number>DR90A3000/U</SKU_SKU_Number> 
    <dynamicAttr>
       <attrName>Power Supply Frequency</attrName>
          <attrValue mLang="1">
            <value lang="en">60 Hz</value>
            <value lang="da-DK"/>
          </attrValue>
          <desc code="">60 Hz</desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Ambient Operating Temperature (Max)</attrName>
          <attrValue mLang="1">
            <value lang="en">90°F </value>
            <value lang="da-DK"/>
          </attrValue>
          <attrValue mLang="1">
            <value lang="en"> 32°C</value>
            <value lang="da-DK"/>
          </attrValue>
          <desc code="">90°F | 32°C</desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Compatible Humidifier Pad</attrName>
          <attrValue mLang="1">
            <value lang="en"/>
            <value lang="da-DK"/>
          </attrValue>
          <desc code=""> </desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Building Size (Max)</attrName>
          <attrValue mLang="1">
            <value lang="en">Up to 20,000 cubic feet</value>
            <value lang="da-DK"/>
          </attrValue>
          <desc code="">Up to 20,000 cubic feet</desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Recommended Service Life</attrName>
          <attrValue mLang="1">
            <value lang="en">10 Years</value>
            <value lang="da-DK"> </value>
          </attrValue>
          <desc code="">10 Years</desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Current Draw</attrName>
          <attrValue mLang="1">
            <value lang="en">0.625 A</value>
            <value lang="da-DK"> </value>
          </attrValue>
          <desc code="">0.625 A</desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Operating Voltage</attrName>
          <attrValue mLang="1">
            <value lang="en">24 VAC</value>
            <value lang="da-DK">25 VAC</value>
            <value lang="da-OTH">26 VAC</value>
          </attrValue>
          <desc code="">24 VAC</desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Static Pressure (Max)</attrName>
          <attrValue mLang="1">
            <value lang="en">0.3 in wc</value>
            <value lang="da-DK"> </value>
          </attrValue>
          <desc code="">0.3 in wc</desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Duct Opening Width</attrName>
          <attrValue> </attrValue>
          <desc code=""> </desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Duct Opening Diameter</attrName>
          <attrValue> </attrValue>
          <desc code=""> </desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Housing Material</attrName>
          <attrValue> </attrValue>
          <desc lang="en"> </desc>
          <desc lang="da-DK"> </desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Duct Opening Height</attrName>
          <attrValue> </attrValue>
          <desc code=""> </desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Building Square Footage (Max)</attrName>
          <attrValue mLang="1">
            <value lang="en"> </value>
            <value lang="da-DK"> </value>
          </attrValue>
          <desc code=""> </desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Power Consumption</attrName>
          <attrValue mLang="1">
            <value lang="en"/>
            <value lang="da-DK"/>
          </attrValue>
          <desc code=""> </desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Mounting Type</attrName>
          <attrValue> </attrValue>
          <desc lang="en"> </desc>
          <desc lang="da-DK"> </desc>
        </dynamicAttr>
        <dynamicAttr>
          <attrName>Remote Mounting Distance (Max)</attrName>
          <attrValue> </attrValue>
          <desc code=""> </desc>
        </dynamicAttr>
  </SKU>
</Root>

所需的输出应该是

假设您的 XML 数据在 @XmlData SQL 变量中 - 您可以使用此 XQuery 获取您要查找的数据:

SELECT
    SkuNumber = XC.value('(SKU_SKU_Number)[1]', 'varchar(50)'),
    AttrName = XC2.value('(attrName)[1]', 'varchar(50)'),
    Lang = xc3.value('@lang', 'varchar(10)'),
    Value = xc3.value('(.)[1]', 'varchar(50)')
FROM
    @XmlData.nodes('/Root/SKU') AS XT(XC)
CROSS APPLY
    XC.nodes('dynamicAttr') AS XT2(XC2)
CROSS APPLY
    XC2.nodes('attrValue/value') AS XT3(XC3)

输出:

built-in 原生 XQuery 支持强烈优于旧的、遗留的(和部分错误的)OPENXML 方法。

基本上,您需要两个嵌套的“循环”——第一个 .nodes() 调用为您获取 <Root> 下的所有 <SKU> 元素(仅此一个)以从中获取数据节点 - 然后您需要“循环” <SKU> 内的所有 <dynamicAttr> XML 元素以获取一些信息,并且您需要再次循环包含的 <attrValue>/<value> 子节点获取最后的详细信息。