自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

詳解XML與DataSet對象的關(guān)系

開發(fā) 后端
.NET中的DataSet與XML之間的關(guān)系,是本文討論的重點。工作中我們經(jīng)常使用XML 作為存儲和傳輸各種數(shù)據(jù)的格式。

在.NET Framework 中,經(jīng)常使用XML 作為存儲和傳輸各種數(shù)據(jù)的格式。

DataSet 中的數(shù)據(jù)可以轉(zhuǎn)換成XML 的形式來表示和存儲。

我們可以使用XML 對象同步和轉(zhuǎn)換DataSet 的數(shù)據(jù),而DataSet 也可以存儲和傳輸XML 格式的數(shù)據(jù)。

XML 與 DataSet 的關(guān)系如下圖所示:

XmlDataDocument_DataSet

DataSet 對象的常用方法如下:

A.  使用ReadXml( ) 方法:從文件或流中加載XML 數(shù)據(jù),填充DataSet 對象。DataSet 對象.ReadXML( 文件路徑字符串|stream 對象, XmlReadMode 枚舉值[可以省略] ) ;

B.  使用WriteXml( ) 方法:將DataSet 對象中的數(shù)據(jù)以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 格式的數(shù)據(jù)集,以字符串的形式獲得。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文檔的數(shù)據(jù)到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中的數(shù)據(jù)寫出到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已經(jīng)擁有一個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 程序的界面效果圖 

原文標(biāo)題:XML 與DataSet 對象的關(guān)系

鏈接:http://www.cnblogs.com/xugang/archive/2010/09/16/1827988.html

【編輯推薦】

  1. W3C發(fā)布XProc規(guī)范 XML企業(yè)級開發(fā)更加輕松
  2. XML新手入門 創(chuàng)建構(gòu)造良好的XML
  3. XML在Web應(yīng)用中的優(yōu)勢 
責(zé)任編輯:彭凡 來源: 博客園
相關(guān)推薦

2009-12-29 14:55:31

ADO.NET Dat

2009-09-08 17:27:18

LINQ to Dat

2010-09-28 11:03:19

XML DOM

2019-05-06 08:37:14

JVMLinux內(nèi)存

2012-05-10 09:44:39

MongoDBJava

2010-01-04 09:40:46

F#對象

2010-09-01 08:57:27

jQueryDOM對象

2009-07-06 15:47:11

Servlet API

2009-10-29 09:48:12

DAO.NET Dat

2009-08-25 17:28:23

C#創(chuàng)建DataSet

2012-04-13 10:45:59

XML

2011-06-24 10:05:51

QT 對象 父對象

2018-07-31 09:38:34

服務(wù)器工作站關(guān)系

2010-06-13 10:19:24

面向?qū)ο蠹夹g(shù)與UML

2009-09-09 15:47:27

XML序列化和反序列化

2012-06-29 13:45:53

XML

2010-03-05 13:28:34

SpringObject XML

2012-08-16 15:56:33

XML

2011-08-22 16:19:58

jQuery

2009-09-14 16:17:03

什么是LINQ To
點贊
收藏

51CTO技術(shù)棧公眾號