`

浅解XML与DataSet对象的关系及转换

阅读更多

在.NET Framework 中,经常使用XML 作为存储和传输各种数据的格式。

DataSet 中的数据可以转换成XML 的形式来表示和存储。

我们可以使用XML 对象同步和转换DataSet 的数据,而DataSet 也可以存储和传输XML 格式的数据。

XML 与 DataSet 的关系如下图所示:

XmlDataDocument_DataSet

DataSet 对象的常用方法如下:

A.  使用ReadXml( ) 方法:从文件或流中加载XML 数据,填充DataSet 对象。DataSet 对象.ReadXML( 文件路径字符串|stream 对象, XmlReadMode 枚举值[可以省略] ) ;

B.  使用WriteXml( ) 方法:将DataSet 对象中的数据以XML 格式写出到文件或流中。DataSet 对象.WriteXml( 文件路径字符串| stream 对象, XmlWriteMode 枚举值[可以省略] ) ;

C.  使用ReadXmlSchema( ) 方法:将Shema 模式文件读入DataSet 对象。DataSet 对象.ReadXmlSchema( Stream | FileName | TextReader | XmlReader ) ;

D.  使用WriteXmlSchema( ) 方法:将DataSet 对象的Shema 模式文件写出到文件或流。DataSet 对象.WriteXmlSchema( Stream | FileName | TextWriter | XmlWriter ) ;

E.  使用GetXmlSchema( ) 方法:将DataSet 对象的Shema 模式,以字符串的形式获得。DataSet 对象.GetXmlSchema( );

F.  使用GetXml( ) 方法:将DataSet 对象的XML 格式的数据集,以字符串的形式获得。DataSet 对象.GetXml( );

接下来,通过一个综合示例进行演示。

Person.xml 文件如下:

  1. <?xml version="1.0" encoding="UTF-8"?>   
  2. <Persons>   
  3.    <person>   
  4.      <ID>0</ID>   
  5.      <Name>Mark</Name>   
  6.      <Age>18</Age>   
  7.    </person>   
  8.    <person>   
  9.      <ID>1</ID>   
  10.      <Name>Jorn</Name>   
  11.      <Age>22</Age>   
  12.    </person>   
  13.    <person>   
  14.      <ID>2</ID>   
  15.      <Name>Aderson</Name>   
  16.      <Age>30</Age>   
  17.    </person>   
  18. </Persons>  

Customer.xsd 文件如下:

  1. <?xml version="1.0" encoding="UTF-8"?>   
  2. <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schema-microsoft-com:xml-msdata" elementFormDefault="qualified" attributeFormDefault="unqualified" id="Customers">   
  3.     <xs:element name="Customers" msdata:IsDataSet="true" msdata:EnforceConstraints="False">   
  4.         <xs:complexType>   
  5.             <xs:choice maxOccurs="unbounded">   
  6.                 <xs:element name="Customer" type="customersType"/>   
  7.             </xs:choice>   
  8.         </xs:complexType>   
  9.     </xs:element>   
  10.     <xs:complexType name="customersType">   
  11.         <xs:sequence>   
  12.             <xs:element name="CustomersID" type="xs:string" minOccurs="0"/>   
  13.             <xs:element name="CustomersName" type="xs:string" minOccurs="0"/>   
  14.             <xs:element name="CustomersAge" type="xs:int" minOccurs="0"/>   
  15.         </xs:sequence>   
  16.     </xs:complexType>   
  17. </xs:schema>  

Winform 程序的源代码如下:

  1. namespace DataSet_XML_Demo   
  2. {   
  3.     public partial class Form1 : Form   
  4.     {   
  5.         public Form1()   
  6.         {   
  7.             InitializeComponent();   
  8.         }   
  9.         DataSet ds = new DataSet();   
  10.     
  11.         //读取XML文档的数据到DataSet   
  12.         private void btnReadXML_Click(object sender, EventArgs e)   
  13.         {   
  14.             ds.ReadXml("http://www.cnblogs.com/" + "Person.xml");   
  15.             dataGridView1.DataSource = ds.Tables[0];   
  16.         }   
  17.     
  18.         //将DataSet中的数据写出到XML文档   
  19.         private void btnWriteXML_Click(object sender, EventArgs e)   
  20.         {   
  21.             ds.WriteXml("http://www.cnblogs.com/New.xml");   
  22.  ds.WriteXml("http://www.cnblogs.com/New_Alter.xml", XmlWriteMode.DiffGram);   
  23.         }   
  24.     
  25.         //加载Schema给DataSet   
  26.         private void btnReadXmlSchema_Click(object sender, EventArgs e)   
  27.         {   
  28.             DataSet newDataSet = new DataSet();   
  29.             newDataSet.ReadXmlSchema("http://www.cnblogs.com/Customer.xsd");   
  30.             dataGridView1.DataSource = newDataSet.Tables[0];   
  31.         }   
  32.     
  33.         //将DataSet的Schema写出   
  34.         private void btnWriteXmlSchema_Click(object sender, EventArgs e)   
  35.         {   
  36.             DataSet newDataSet = new DataSet();   
  37.             DataTable dt = new DataTable();   
  38.             DataColumn dc1 = new DataColumn("id"typeof(int));   
  39.             DataColumn dc2 = new DataColumn("name"typeof(string));   
  40.             dt.Columns.Add(dc1);   
  41.             dt.Columns.Add(dc2);   
  42.             newDataSet.Tables.Add(dt);   
  43.     
  44.             dataGridView1.DataSource = newDataSet;   
  45.             dataGridView1.DataMember = "Table1";   
  46.   newDataSet.WriteXmlSchema("http://www.cnblogs.com/newSchema.xsd");   
  47.         }   
  48.     
  49.         //GetXml()方法的使用   
  50.         private void btnGetXml_Click(object sender, EventArgs e)   
  51.         {   
  52.             DataSet newXml = new DataSet();   
  53.             newXml.ReadXml("http://www.cnblogs.com/" + "Person.xml");   
  54.             dataGridView1.DataSource = newXml.Tables[0];   
  55.     
  56.             //GetXml():返回DataSet中XML形式的字符串   
  57.             string strXml = newXml.GetXml();   
  58.             textBox1.Text = strXml;   
  59.         }   
  60.     
  61.         //GetXmlSchema()方法的使用   
  62.         private void btnGetXmlSchema_Click(object sender, EventArgs e)   
  63.         {   
  64.              /* 注意:   
  65.                 如果DataSet已经拥有一个Schema模式,   
  66.                 再加载新的Schema模式文件,   
  67.                 则会自动将两个Schema模式合并。   
  68.              */   
  69.             DataSet newSchema = new DataSet();   
  70.       newSchema.ReadXmlSchema("http://www.cnblogs.com/Customer.xsd");   
  71.             dataGridView1.DataSource = newSchema.Tables[0];   
  72.     
  73.             //GetXmlSchema():返回DataSet所使用的Schema模式文件的字符串   
  74.             string strSchema = newSchema.GetXmlSchema();   
  75.             textBox1.Text = strSchema;   
  76.         }   
  77.     }   
  78. }  

Winform 程序的界面效果如下:

Winform 程序的界面效果图 

分享到:
评论

相关推荐

    asp.net提供XML与dataset互相转换

    在asp.net中提供了数据集DateSet与Xml转换的类 XmlDatasetConvert code: XmlDatasetConvert 该类提供了四种方法: 1、将xml对象内容字符串转换为DataSet 2、将xml文件转换为DataSet 3、将DataSet转换为...

    xml字符串转化Dataset

    用C#编程实现显示XML文件中信息的方法是使用.NET提供的标准类把XML文件内容读入一个StreamReader类对象中,再用XmlDatadocument类的DataSet读XML的方法去读XML信息到DataSet中,DataSet再以DataView的方式赋给一个Web...

    DataSetConverter4Delphi, 将JSON对象和数据集转换为JSON对象的API.zip

    DataSetConverter4Delphi, 将JSON对象和数据集转换为JSON对象的API Delphi的数据集转换器xml是转换JSON对象和数据集的API,也执行反向处理,数据集JSON转换。TDataSet和 TJSONObject TJSONArray类一起工作。要使用这...

    LINQ XML控制类

    /// 将xml对象转化成DataTable /// /// &lt;returns&gt;&lt;/returns&gt; public DataTable CoverToTable() { if (this._xmlDocumentdoc != null) { DataSet dsxml = null; using (XmlReader reader = new ...

    C#XML入门经典 C#编程人员必备的XML技能.part2

    XML概述 &lt;br&gt;2.1 XML的概念 2.1.1 XML元素 2.1.2 XML属性 2.1.3 XML解析器 2.1.4 构建XML 2.1.5 XML文档的各个组成部分 2.2 创建格式良好的XML文档 2.2.1 XML中的元素 2.2.2 XML中的属性...

    ado[1].net中文手册 学习 ado.net的重要资料

    XML 和 DataSet:描述 DataSet 如何与作为数据源的 XML 进行交互(包括以 XML 数据的形式加载和保持 DataSet 的内容)。 DiffGram:提供有关 DiffGram 的详细信息,DiffGram 是一种用于读写 DataSet 内容的 XML 格式...

    ADO.NET本质论.pdf

    4.2 dataset对象模型 4.2.1 datacolumn,datarow和data table 4.2.2 data table及其用法 4.2.3 datarow 4.2.4 键、关系和约束 4.2.5 通过关系来导航:select和find 4.2.6 行的添加、获取、更改和...

    C#实现DataSet内数据转化为Excel和Word文件的通用类完整实例

    前不久因为项目的需要写的一个C#把DataSet内数据转化为Excel和Word文件的通用类,这些关于Excel、Word的导出方法,基本可以实现日常须要,其中有些方法可以把数据导出后 生成Xml格式,再导入数据库!有些屏蔽内容没有...

    LINQ 实战 1/11

    7.1 对象与关系数据的映射 180 7.1.1 通过在类中添加属性 181 7.1.2 使用外部XML文件实现映射 185 7.1.3 使用SqlMetal工具 186 7.1.4 LINQ to SQL设计器 188 7.2 将查询表达式转换为SQL 190 7.2.1 ...

    LINQ 实战 3/11

    7.1 对象与关系数据的映射 180 7.1.1 通过在类中添加属性 181 7.1.2 使用外部XML文件实现映射 185 7.1.3 使用SqlMetal工具 186 7.1.4 LINQ to SQL设计器 188 7.2 将查询表达式转换为SQL 190 7.2.1 ...

    LINQ 实战 4/11

    7.1 对象与关系数据的映射 180 7.1.1 通过在类中添加属性 181 7.1.2 使用外部XML文件实现映射 185 7.1.3 使用SqlMetal工具 186 7.1.4 LINQ to SQL设计器 188 7.2 将查询表达式转换为SQL 190 7.2.1 ...

    LINQ 实战 2/11

    7.1 对象与关系数据的映射 180 7.1.1 通过在类中添加属性 181 7.1.2 使用外部XML文件实现映射 185 7.1.3 使用SqlMetal工具 186 7.1.4 LINQ to SQL设计器 188 7.2 将查询表达式转换为SQL 190 7.2.1 ...

    LINQ 实战 7/11

    7.1 对象与关系数据的映射 180 7.1.1 通过在类中添加属性 181 7.1.2 使用外部XML文件实现映射 185 7.1.3 使用SqlMetal工具 186 7.1.4 LINQ to SQL设计器 188 7.2 将查询表达式转换为SQL 190 7.2.1 ...

    LINQ 实战 11/11

    7.1 对象与关系数据的映射 180 7.1.1 通过在类中添加属性 181 7.1.2 使用外部XML文件实现映射 185 7.1.3 使用SqlMetal工具 186 7.1.4 LINQ to SQL设计器 188 7.2 将查询表达式转换为SQL 190 7.2.1 ...

    LINQ 实战 5/11

    7.1 对象与关系数据的映射 180 7.1.1 通过在类中添加属性 181 7.1.2 使用外部XML文件实现映射 185 7.1.3 使用SqlMetal工具 186 7.1.4 LINQ to SQL设计器 188 7.2 将查询表达式转换为SQL 190 7.2.1 ...

    LINQ 实战 6/11

    7.1 对象与关系数据的映射 180 7.1.1 通过在类中添加属性 181 7.1.2 使用外部XML文件实现映射 185 7.1.3 使用SqlMetal工具 186 7.1.4 LINQ to SQL设计器 188 7.2 将查询表达式转换为SQL 190 7.2.1 ...

    LINQ 实战 8/11

    7.1 对象与关系数据的映射 180 7.1.1 通过在类中添加属性 181 7.1.2 使用外部XML文件实现映射 185 7.1.3 使用SqlMetal工具 186 7.1.4 LINQ to SQL设计器 188 7.2 将查询表达式转换为SQL 190 7.2.1 ...

    LINQ 实战 10/11

    7.1 对象与关系数据的映射 180 7.1.1 通过在类中添加属性 181 7.1.2 使用外部XML文件实现映射 185 7.1.3 使用SqlMetal工具 186 7.1.4 LINQ to SQL设计器 188 7.2 将查询表达式转换为SQL 190 7.2.1 ...

    LINQ 实战 9/11

    7.1 对象与关系数据的映射 180 7.1.1 通过在类中添加属性 181 7.1.2 使用外部XML文件实现映射 185 7.1.3 使用SqlMetal工具 186 7.1.4 LINQ to SQL设计器 188 7.2 将查询表达式转换为SQL 190 7.2.1 ...

    Dataset_processing:用于自动浏览带注释的数据集,创建统计信息以及(可选)从txt或XML文件创建COCO样式的JSON的工具

    说明:存储库可探索任何带注释的数据集并创建COCO样式的JSON文件,以在带注释的数据集上训练对象检测器。 该存储库支持XML和TXT文件。 摘要统计 Images: 4080 Categories: 20 Total instances: 32964 仅用于统计 ...

Global site tag (gtag.js) - Google Analytics