Megjegyzés
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhat bejelentkezni vagy módosítani a címtárat.
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhatja módosítani a címtárat.
A következőkre vonatkozik:SQL Server
Azure SQL Database
Mivel az XML Bulk Load rekordokat generál, amikor a csomópontok lépnek a hatókörbe, és ezeket a rekordokat a Microsoft SQL Server-nek küldi, amikor a csomópontok kilépnek a hatókörből, a rekord adatainak a csomópont hatókörén belül kell lenniük.
Vegyük a következő XSD sémát, amelyben az ügyfél> és a rendelés elemek közötti egy-többhez kapcsolatot< (egy ügyfél sok rendelést adhat ki) a <sql:relationship> elem segítségével van meghatározva:><
<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema"<>
xmlns:sql="urn:schemas-microsoft-com:mapping-schema">
<xsd:annotation>
<xsd:appinfo>
<sql:relationship name="CustCustOrder"
parent="Cust"
parent-key="CustomerID"
child="CustOrder"
child-key="CustomerID" />
</xsd:appinfo>
</xsd:annotation>
<xsd:element name="Customers" sql:relation="Cust" >
<xsd:complexType>
<xsd:sequence>
<xsd:element name="CustomerID" type="xsd:integer" />
<xsd:element name="CompanyName" type="xsd:string" />
<xsd:element name="City" type="xsd:string" />
<xsd:element name="Order"
sql:relation="CustOrder"
sql:relationship="CustCustOrder" >
<xsd:complexType>
<xsd:attribute name="OrderID" type="xsd:integer" />
</xsd:complexType>
</xsd:element>
</xsd:sequence>
</xsd:complexType>
</xsd:element>
</xsd:schema>
Ahogy az <ügyfélelem> csomópontja lép be a hatókörbe, az XML Bulk Load ügyfélrekordot generál. Ez a rekord addig marad, amíg az XML Bulk Load fel nem <olvassa a /Customer-et>. A< Order> elem csomópont feldolgozása során az XML Bulk Load sql<:relationship> segítségével megkapja a CustOrder tábla CustomerID idegen kulcsoszlopának értékét a <Customer> parent elemtől, mivel a< Order> elem nem határozza meg a CustomerID attribútumot. Ez azt jelenti, hogy a <Customer> elem meghatározásához a sémában meg kell határoznod a CustomerID attribútumot, mielőtt megadnánk< a sql:relationship-et>. Ellenkező esetben, amikor egy <Order> elem lép be a scope-ba, az XML Bulk Load egy rekordot generál a CustOrder táblához, és amikor az XML Bulk Load eléri a </Order> végcímkét, a rekordot az SQL Servernek küldi a CustomerID külföldi kulcsoszlop értéke nélkül.
A példában megadott sémát SampleSchema.xml.
Egy működő minta teszteléséhez
Hozza létre a következő táblázatokat:
CREATE TABLE Cust ( CustomerID int PRIMARY KEY, CompanyName varchar(20) NOT NULL, City varchar(20) DEFAULT 'Seattle') GO CREATE TABLE CustOrder ( OrderID varchar(10) PRIMARY KEY, CustomerID int FOREIGN KEY REFERENCES Cust(CustomerID)) GOA következő mintaadatokat elmentsük SampleXMLData.xml:
<ROOT> <Customers> <CompanyName>Hanari Carnes</CompanyName> <City>NY</City> <Order OrderID="1" /> <Order OrderID="2" /> <CustomerID>1111</CustomerID> </Customers> <Customers> <CompanyName>Toms Spezialitten</CompanyName> <City>LA</City> <Order OrderID="3" /> <CustomerID>1112</CustomerID> </Customers> <Customers> <CompanyName>Victuailles en stock</CompanyName> <Order OrderID="4" /> <CustomerID>1113</CustomerID> </Customers> </ROOT>Az XML Bulk Load végrehajtásához mentse el és hajtsa végre a következő Microsoft Visual Basic Scripting Edition (VBScript) példát MySample.vbs néven:
set objBL = CreateObject("SQLXMLBulkLoad.SQLXMLBulkload.4.0") objBL.ConnectionString = "provider=SQLOLEDB;data source=localhost;database=tempdb;integrated security=SSPI" objBL.ErrorLogFile = "c:\error.log" objBL.CheckConstraints = True objBL.Transaction=True objBL.Execute "c:\SampleSchema.xml", "c:\SampleXMLData.xml" set objBL=NothingEnnek eredményeként az XML Bulk Load egy NULL értéket helyez be a CustOrder tábla CustomerID idegen kulcsoszlopába. Ha módosítod az XML mintaadatot úgy, hogy a <CustomerID> gyermekelem megjelenik a <Order> gyermek elem előtt, akkor a várható eredményt kapjuk: az XML Bulk Load beilleszti a megadott külföldi kulcsértéket az oszlopba.
Ez a megfelelő XDR-séma:
<?xml version="1.0" ?>
<Schema xmlns="urn:schemas-microsoft-com:xml-data"
xmlns:dt="urn:schemas-microsoft-com:xml:datatypes"
xmlns:sql="urn:schemas-microsoft-com:xml-sql" >
<ElementType name="CustomerID" />
<ElementType name="CompanyName" />
<ElementType name="City" />
<ElementType name="root" sql:is-constant="1">
<element type="Customers" />
</ElementType>
<ElementType name="Customers" sql:relation="Cust" >
<element type="CustomerID" sql:field="CustomerID" />
<element type="CompanyName" sql:field="CompanyName" />
<element type="City" sql:field="City" />
<element type="Order" >
<sql:relationship
key-relation ="Cust"
key ="CustomerID"
foreign-key ="CustomerID"
foreign-relation="CustOrder" />
</element>
</ElementType>
<ElementType name="Order" sql:relation="CustOrder" >
<AttributeType name="OrderID" />
<AttributeType name="CustomerID" />
<attribute type="OrderID" />
<attribute type="CustomerID" />
</ElementType>
</Schema>