解析列中的 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>
子节点获取最后的详细信息。
需要帮助来解析下面的 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>
子节点获取最后的详细信息。