我希望这个论坛可以帮助我。我对 OpenXML 一无所知,我必须将几个文件加载到 SQL Server 2012。源更改了文件格式以包含嵌入式 xsd 架构,但我遇到了麻烦。如果我修改它以开始并取出所有 xsd 东西,我可以调用这些值。大多数文件都非常大,无法全部编辑,所以我需要弄清楚如何在不编辑的情况下查询它。下面是我在从中删除 xsd 行的文件上使用的查询。可以在此处获取未经编辑的 xml 的副本 https://drive.google.com/file/d/1CIeDWTSAHFCIyz8F2zrtLCDpqe-uUeJv/view?usp=sharing
论坛上的这篇文章看起来像我需要的,但我真的不明白它与我的文件一起使用。 带有 xmlns:dt 的 OPENXML
DECLARE @fileData XML
SELECT @fileData = BulkColumn
FROM OpenRowSet(BULK 'C:\ogrid - Copy.xml',Single_blob) x;
SELECT
xdata.value('ogrid_cde[1]','int') ogrid_cde,
xData.value('ogrid_nam[1]','nvarchar(255)') ogrid_name,
xData.value('ogrid_adr_nam[1]','nvarchar(255)') ogrid_adr_name,
xData.value('mail_stop[1]','nvarchar(255)') mail_stop,
xData.value('line1_adr[1]','nvarchar(255)') line1_adr,
xData.value('line2_adr[1]','nvarchar(255)') line2_adr,
xData.value('line3_adr[1]','nvarchar(255)') line3_adr,
xData.value('city_nam[1]','nvarchar(255)') city_name,
xData.value('st_nam[1]','nvarchar(255)') st_name,
xData.value('zip_cde[1]','nvarchar(255)') zip_cde,
xData.value('ctry_nam[1]','nvarchar(255)') ctry_name,
xData.value('phone_num[1]','decimal(28,10)') phone_num,
xData.value('fax_num[1]','decimal(28,10)') fax_num,
xData.value('stat_eff_dte[1]','datetime') stat_eff_dte,
xData.value('issng_ag_cde[1]','nvarchar(255)') issng_ag_cde,
xData.value('lst_modified_dte[1]','datetime') last_modified_dte,
xData.value('created_dte[1]','datetime') created_dte,
xData.value('ogrid_stat_cde[1]','nvarchar(255)') ogrid_stat_cde
FROM
@fileData.nodes('root/ogrid') AS x(xData)
这是从源接收时包含 xsd 的文件的示例。
<root xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<xsd:schema targetNamespace="urn:schemas-microsoft-com:sql:SqlRowSet1"
xmlns:schema="urn:schemas-microsoft-com:sql:SqlRowSet1"
xmlns:xsd="http://www.w3.org/2001/XMLSchema"
xmlns:sqltypes="http://schemas.microsoft.com/sqlserver/2004/sqltypes"
elementFormDefault="qualified">
<xsd:import namespace="http://schemas.microsoft.com/sqlserver/2004/sqltypes"
schemaLocation="http://schemas.microsoft.com/sqlserver/2004/sqltypes/sqltypes.xsd"/>
<xsd:element name="ogrid">
<xsd:complexType>
<xsd:sequence>
<xsd:element name="ogrid_cde" type="sqltypes:int" nillable="1"/>
<xsd:element name="ogrid_nam" nillable="1">
<xsd:simpleType>
<xsd:restriction base="sqltypes:char" sqltypes:localeId="1033" sqltypes:sqlCompareOptions="IgnoreCase IgnoreKanaType IgnoreWidth" sqltypes:sqlSortId="52">