Partager via


Exemple de synchronisation d'un DataSet avec un XmlDataDocument

Cette section décrit l'une des étapes du traitement d'un bon de commande à l'aide d'un DataSet fortement typé, synchronisé avec un XmlDataDocument. Les exemples ci-dessous créent un DataSet avec un schéma minimal ne correspondant qu'à une partie du document XML source. Ces exemples utiliseront un XmlDataDocument pour préserver la fidélité du document XML source, de sorte que le DataSet pourra être utilisé pour exposer un sous-ensemble du document XML.

Le document XML suivant contient toutes les informations figurant sur un bon de commande : informations sur le client, articles commandés, informations de livraison, etc.

<?xml version="1.0" standalone="yes"?>
<PurchaseOrder>
  <Customers>
    <CustomerID>CHOPS</CustomerID>
    <Orders>
      <OrderID>10966</OrderID>
      <OrderDetails>
        <OrderID>10966</OrderID>
        <ProductID>37</ProductID>
        <UnitPrice>26</UnitPrice>
        <Quantity>8</Quantity>
        <Discount>0</Discount>
      </OrderDetails>
      <OrderDetails>
        <OrderID>10966</OrderID>
        <ProductID>56</ProductID>
        <UnitPrice>38</UnitPrice>
        <Quantity>12</Quantity>
        <Discount>0.15</Discount>
      </OrderDetails>
      <OrderDetails>
        <OrderID>10966</OrderID>
        <ProductID>62</ProductID>
        <UnitPrice>49.3</UnitPrice>
        <Quantity>12</Quantity>
        <Discount>0.15</Discount>
      </OrderDetails>
      <CustomerID>CHOPS</CustomerID>
      <EmployeeID>4</EmployeeID>
      <OrderDate>1998-03-20T00:00:00.0000000</OrderDate>
      <RequiredDate>1998-04-17T00:00:00.0000000</RequiredDate>
      <ShippedDate>1998-04-08T00:00:00.0000000</ShippedDate>
      <ShipVia>1</ShipVia>
      <Freight>27.19</Freight>
      <ShipName>Chop-suey Chinese</ShipName>
      <ShipAddress>Hauptstr. 31</ShipAddress>
      <ShipCity>Bern</ShipCity>
      <ShipPostalCode>3012</ShipPostalCode>
      <ShipCountry>Switzerland</ShipCountry>
    </Orders>
    <CompanyName>Chop-suey Chinese</CompanyName>
    <ContactName>Yang Wang</ContactName>
    <ContactTitle>Owner</ContactTitle>
    <Address>Hauptstr. 29</Address>
    <City>Bern</City>
    <PostalCode>3012</PostalCode>
    <Country>Switzerland</Country>
    <Phone>0452-076545</Phone>
  </Customers>
  <Shippers>
    <ShipperID>1</ShipperID>
    <CompanyName>Speedy Express</CompanyName>
    <Phone>(503) 555-9831</Phone>
  </Shippers>
  <Shippers>
    <ShipperID>2</ShipperID>
    <CompanyName>United Package</CompanyName>
    <Phone>(503) 555-3199</Phone>
  </Shippers>
  <Shippers>
    <ShipperID>3</ShipperID>
    <CompanyName>Federal Shipping</CompanyName>
    <Phone>(503) 555-9931</Phone>
  </Shippers>
  <Products>
    <ProductID>37</ProductID>
    <ProductName>Gravad lax</ProductName>
    <QuantityPerUnit>12 - 500 g pkgs.</QuantityPerUnit>
    <UnitsInStock>11</UnitsInStock>
    <UnitsOnOrder>50</UnitsOnOrder>
    <ReorderLevel>25</ReorderLevel>
  </Products>
  <Products>
    <ProductID>56</ProductID>
    <ProductName>Gnocchi di nonna Alice</ProductName>
    <QuantityPerUnit>24 - 250 g pkgs.</QuantityPerUnit>
    <UnitsInStock>21</UnitsInStock>
    <UnitsOnOrder>10</UnitsOnOrder>
    <ReorderLevel>30</ReorderLevel>
  </Products>
  <Products>
    <ProductID>62</ProductID>
    <ProductName>Tarte au sucre</ProductName>
    <QuantityPerUnit>48 pies</QuantityPerUnit>
    <UnitsInStock>17</UnitsInStock>
    <UnitsOnOrder>0</UnitsOnOrder>
    <ReorderLevel>0</ReorderLevel>
  </Products>
</PurchaseOrder>

L'une des étapes du traitement des informations du bon de commande contenu dans le document XML précédent consiste à satisfaire la commande en allant chercher les articles dans le stock actuel de la société. L'employé chargé de cette tâche n'a pas besoin pour ce faire de voir l'intégralité du contenu du bon de commande ; il lui suffit de connaître les références des produits commandés. Pour n'exposer que les références des produits à partir du document XML, créez un DataSet fortement typé avec un schéma, écrit sous la forme d'un schéma en langage XSD (XML Schema Definition), qui corresponde aux produits et quantités commandés. Pour plus d'informations sur les objets DataSet fortement typés, consultez Utilisation d'un DataSet typé.

Le code suivant montre le schéma à partir duquel le DataSet fortement typé de cet exemple est généré.

<?xml version="1.0" standalone="yes"?>
<xs:schema id="OrderDetail"  
                            xmlns:xs="http://www.w3.org/2001/XMLSchema" 
                            xmlns:codegen="urn:schemas-microsoft-com:xml-msprop" 
                            xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
  <xs:element name="OrderDetail" msdata:IsDataSet="true">
    <xs:complexType>
      <xs:choice maxOccurs="unbounded">
        <xs:element name="OrderDetails" codegen:typedName="LineItem" codegen:typedPlural="LineItems">
          <xs:complexType>
            <xs:sequence>
              <xs:element name="OrderID" type="xs:int" minOccurs="0" codegen:typedName="OrderID"/>
              <xs:element name="Quantity" type="xs:short" minOccurs="0" codegen:typedName="Quantity"/>
              <xs:element name="ProductID" type="xs:int" minOccurs="0" codegen:typedName="ProductID"/>
            </xs:sequence>
          </xs:complexType>
        </xs:element>
        <xs:element name="Products" codegen:typedName="Product" codegen:typedPlural="Products">
          <xs:complexType>
            <xs:sequence>
              <xs:element name="ProductID" type="xs:int" minOccurs="0" codegen:typedName="ProductID"/>
              <xs:element name="ProductName" type="xs:string" minOccurs="0" codegen:typedName="ProductName"/>
              <xs:element name="QuantityPerUnit" type="xs:string" minOccurs="0" codegen:typedName="QuantityPerUnit"/>
              <xs:element name="UnitsInStock" type="xs:short" minOccurs="0" codegen:typedName="UnitsInStock"/>
              <xs:element name="UnitsOnOrder" type="xs:short" minOccurs="0" codegen:typedName="UnitsOnOrder"/>
              <xs:element name="ReorderLevel" type="xs:short" minOccurs="0" codegen:typedName="ReorderLevel"/>
            </xs:sequence>
          </xs:complexType>
        </xs:element>
      </xs:choice>
    </xs:complexType>
    <xs:unique name="Constraint1">
      <xs:selector xpath=".//Products" />
      <xs:field xpath="ProductID" />
    </xs:unique>
    <xs:keyref name="Relation1" refer="Constraint1" codegen:typedChildren="GetLineItems" codegen:typedParent="Product">
      <xs:selector xpath=".//OrderDetails" />
      <xs:field xpath="ProductID" />
    </xs:keyref>
  </xs:element>
</xs:schema>

Notez que seules les informations des éléments OrderDetails et Products du document XML d'origine sont inclus dans le schéma du DataSet. Synchroniser le DataSet avec un XmlDataDocument permet de s'assurer que les éléments qui ne sont pas inclus dans le DataSet seront conservés avec le document XML.

Grâce au DataSet fortement typé généré à partir du schéma XML (avec l'espace de noms Northwind.FillOrder), une partie du document XML d'origine peut être exposée via la synchronisation du DataSet avec le XmlDataDocument chargé à partir du document XML source. Notez que le DataSet généré à partir du schéma contient une structure, mais pas de données. Les données sont fournies lorsque vous chargez le XML dans le XmlDataDocument. Si vous tentez de charger un XmlDataDocument qui a été synchronisé avec un DataSet qui contient déjà des données, une exception sera levée.

Après mise à jour du DataSet (et du XmlDataDocument), le XmlDataDocument peut écrire le document XML modifié, en laissant intacts les éléments ignorés par le DataSet, comme illustré ci-dessous. Dans le scénario du bon de commande, une fois que les articles commandés ont été sortis du magasin, le document XML modifié peut passer à l'étape suivante du traitement de la commande, peut-être au service livraison de la société.

Imports System
Imports System.Data
Imports System.Xml
Imports Northwind.FillOrder

Public class Sample
  Public Shared Sub Main()

    Dim orderDS As OrderDetail = New OrderDetail

    Dim xmlDoc As XmlDataDocument = New XmlDataDocument(orderDS) 

    xmlDoc.Load("Order.xml")

    Dim myItem As OrderDetail.LineItem
    Dim myProd As OrderDetail.Product

    For Each myItem In orderDS.LineItems
      myProd = myItem.Product

      ' Remove quantity from the current stock.
      myProd.UnitsInStock = CType(myProd.UnitsInStock - myItem.Quantity, Short)

      ' If the remaining stock is less than the reorder level, order more.
      If ((myProd.UnitsInStock + myProd.UnitsOnOrder) < myProd.ReorderLevel) Then
        myProd.UnitsOnOrder = CType(myProd.UnitsOnOrder + myProd.ReorderLevel, Short)
      End If
    Next

    xmlDoc.Save("Order_out.xml")
  End Sub
End Class
[C#]
using System;
using System.Data;
using System.Xml;
using Northwind.FillOrder;

public class Sample
{
  public static void Main()
  {
    OrderDetail orderDS = new OrderDetail();

    XmlDataDocument xmlDoc = new XmlDataDocument(orderDS); 

    xmlDoc.Load("Order.xml");

    foreach (OrderDetail.LineItem myItem in orderDS.LineItems)
    {
      OrderDetail.Product myProd = myItem.Product;

      // Remove quantity from the current stock.
      myProd.UnitsInStock = (short)(myProd.UnitsInStock - myItem.Quantity);

      // If the remaining stock is less than the reorder level, order more.
      if ((myProd.UnitsInStock + myProd.UnitsOnOrder) < myProd.ReorderLevel)
        myProd.UnitsOnOrder = (short)(myProd.UnitsOnOrder + myProd.ReorderLevel);
    }

    xmlDoc.Save("Order_out.xml");
  }
}

Voir aussi

Synchronisation d'un DataSet avec un XmlDataDocument