分享
 
 
 

使用.NET存储XML数据(二)

王朝c#·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

映射XML订单

假定你在编写一个接受用户订单的应用程序,订单是XML格式的,它的XSD大纲如图1定义。该大纲定义了三种复合类型,分别提供订单的客户数据、订单数据和线性数据项。一个顶层Customer元素定义了XML文档的根。这个封闭的系统定义了元素之间的关系:Order元素包含了一个LineItem元素,Customer元素包含一个Order元素。图2显示了符合图1定义的大纲的一个XML文档实例。

图1:XSD大纲

<?xml version="1.0" encoding="utf-8"?>

<xs:schema targetNamespace="urn:Sep2003Example" elementFormDefault="qualified"

xmlns="urn:Sep2003Example"

xmlns:xs="http://www.w3.org/2001/XMLSchema">

<xs:complexType name="OrderType">

<xs:sequence>

<xs:element name="OrderID" type="xs:integer" />

<xs:element name="LineItem" type="LineItemType" />

</xs:sequence>

</xs:complexType>

<xs:complexType name="LineItemType">

<xs:sequence>

<xs:element name="ProductID" type="xs:int" />

<xs:element name="Quantity" type="xs:int" />

<xs:element name="UnitPrice" type="xs:decimal" />

</xs:sequence>

</xs:complexType>

<xs:complexType name="CustomerType">

<xs:sequence>

<xs:element name="CustomerID" type="xs:string" />

<xs:element name="Order" type="OrderType" />

</xs:sequence>

</xs:complexType>

<xs:element name="Customer" type="CustomerType">

</xs:element>

</xs:schema>

图2:一个XML文档示例

<?xml version="1.0" ?>

<Customer xmlns="urn:Sep2003Example">

<CustomerID>ALFKI</CustomerID>

<PO>9572658</PO>

<Address>

<Street>One Main Street</Street>

<City>Anywhere</City>

<State>NJ</State>

<Zip>08080</Zip> </Address>

<Order>

<OrderID>10966</OrderID>

<LineItem>

<ProductID>37</ProductID>

<UnitPrice>26.50</UnitPrice>

<Quantity>8</Quantity>

<Description>Gravad lax</Description>

</LineItem>

<LineItem>

<ProductID>56</ProductID>

<UnitPrice>38.00</UnitPrice>

<Quantity>12</Quantity>

<Description>Gnocchi di nonna Alice</Description>

</LineItem>

</Order>

</Customer>

列表1中显示的C#代码使用ReadXmlSchema方法把图1中的大纲载入一个叫作orderDS的数据集中。ReadXmlSchema建立了三个数据表,它们分别与大纲中定义的Customer、Order和LineItem元素对应。因此你可以验证这个大纲在关系数据缓存中建立了预期的表,printDSShape方法把每个表的名称写到控制台上,后面跟着列的列表和每列的数据类型。

列表1: 建立关系数据缓存的C#代码

using System;

using System.Collections;

using System.Data;

using System.Data.SqlClient;

using System.Xml;

public class XMLMap

{

public static void Main()

{

// 建立数据集和读取大纲

DataSet orderDS = new DataSet("CustOrder");

orderDS.ReadXmlSchema("CustOrderLitem.xsd");

// 打印数据集的形式

printDSShape(orderDS);

// 把一个XML格式的订单读入数据集

orderDS.ReadXml("Order.xml",System.Data.XmlReadMode.IgnoreSchema);

// 打印数据集中的数据

printDSData(orderDS);

// 此处插入业务规则和数据库更新逻辑

}

private static void printDSShape(DataSet ds)

{

foreach (DataTable dt in ds.Tables)

{

Console.WriteLine("{0}",dt.TableName);

// 打印列的名称和类型

foreach (DataColumn dc in dt.Columns)

Console.WriteLine("\t{0}\t{1}",dc.ColumnName,dc.DataType.ToString());

}

}

private static void printDSData(DataSet ds)

{

foreach (DataTable dt in ds.Tables)

{

Console.WriteLine("\n{0}:", dt.TableName);

// 打印列的头

foreach (DataColumn dc in dt.Columns)

Console.Write("{0}\t",dc.ColumnName);

Console.WriteLine("");

// 输出数据

foreach (DataRow dr in dt.Rows)

{

foreach(DataColumn dc in dt.Columns)

System.Console.Write("{0}\t",dr[dc]);

System.Console.WriteLine("");

}

}

}

}

仔细查看一下列的名称。尽管大纲中没有指定Customer_Id和Order_Id列,但是它们还是出现在数据表中。ReadXmlSchema给数据集自动添加这些列。数据集把这些列用作外部键(foreign key),以模拟Customer元素与它的Order元素之间、Order元素与它的LineItem元素之间的关系。因为典型情况下XML使用嵌套的关系代替了外部键,所以数据集自动生成自己的主键、数据表之间的外部键,并把它们存储在这些列中。

请同时仔细查看图3中的数据类型--数据集已经把来自XML大纲数据类型的数据类型映射为对应的.NET数据类型。当你把XML文档载入数据集的时候,该数据集把来自XML的每一个值转换为对应的.NET类型。

图3:生成的数据类型和记录

Customer

CustomerID System.String

Customer_Id System.Int32

Order

OrderID System.Int64

Order_Id System.Int32

Customer_Id System.Int32

LineItem

ProductID System.Int32

Quantity System.Int32

UnitPrice System.Decimal

Order_Id System.Int32

Customer:

CustomerID Customer_Id

ALFKI 0

Order:

OrderID Order_Id Customer_Id

10966 0 0

LineItem:

ProductID Quantity UnitPrice Order_Id

37 8 26.5 0

56 12 38 0

把大纲载入数据集之后,为了完成关系映射,你需要做的所有事情就是把XML数据载入该数据集。列表1的ReadXml方法打开叫作Order.xml的文件,该文件如图2所示。接着,它把文件中的数据读取到你刚才读取大纲建立的数据集中的数据表里。你的XML订单现在可以通过数据集访问了。

为了演示如何访问数据集中的数据,列表1的printDSData方法在数据表中导航,对于每张表,都显示列的名称,紧接着显示这张表的所有的行。图3显示为ReadXmlSchema方法给数据集添加的Customer_Id和Order_Id列自动生成了值。

请注意,Order.xml出现的三个元素--PO、Address和Description--没有映射到数据表中。这些数据被忽略了,因为你提供给数据集的大纲没有包含这些元素,当数据集建立关系数据缓存的外形并载入XML数据的时候,它简单地忽略了没有在大纲中描述的数据。即使在你从客户那儿接收到的XML订单中包含了没有预料到的额外数据,这种简便特性也可以让你的代码正常地工作。

建立使用数据缓存的应用程序

现在你已经知道如何使用数据集为XML数据建立关系数据缓存了,你可以应用这种技术来实现一个执行业务逻辑并更新SQL Server的应用程序。当你使用数据集编程模型的时候实现业务逻辑相对直接。ADO.NET为你提供了更新SQL Server中数据的几种选择,包括使用数据适配器、编写自己的查询,以及执行存储过程。数据集使把XML数据映射成关系模型很容易,剩余的事情是你的了。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有