詳解XML與DataSet對象的關(guān)系
在.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)系如下圖所示:
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 文件如下:
- <?xml version="1.0" encoding="UTF-8"?>
- <Persons>
- <person>
- <ID>0</ID>
- <Name>Mark</Name>
- <Age>18</Age>
- </person>
- <person>
- <ID>1</ID>
- <Name>Jorn</Name>
- <Age>22</Age>
- </person>
- <person>
- <ID>2</ID>
- <Name>Aderson</Name>
- <Age>30</Age>
- </person>
- </Persons>
Customer.xsd 文件如下:
- <?xml version="1.0" encoding="UTF-8"?>
- <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schema-microsoft-com:xml-msdata" elementFormDefault="qualified" attributeFormDefault="unqualified" id="Customers">
- <xs:element name="Customers" msdata:IsDataSet="true" msdata:EnforceConstraints="False">
- <xs:complexType>
- <xs:choice maxOccurs="unbounded">
- <xs:element name="Customer" type="customersType"/>
- </xs:choice>
- </xs:complexType>
- </xs:element>
- <xs:complexType name="customersType">
- <xs:sequence>
- <xs:element name="CustomersID" type="xs:string" minOccurs="0"/>
- <xs:element name="CustomersName" type="xs:string" minOccurs="0"/>
- <xs:element name="CustomersAge" type="xs:int" minOccurs="0"/>
- </xs:sequence>
- </xs:complexType>
- </xs:schema>
Winform 程序的源代碼如下:
- namespace DataSet_XML_Demo
- {
- public partial class Form1 : Form
- {
- public Form1()
- {
- InitializeComponent();
- }
- DataSet ds = new DataSet();
- //讀取XML文檔的數(shù)據(jù)到DataSet
- private void btnReadXML_Click(object sender, EventArgs e)
- {
- ds.ReadXml("http://www.cnblogs.com/" + "Person.xml");
- dataGridView1.DataSource = ds.Tables[0];
- }
- //將DataSet中的數(shù)據(jù)寫出到XML文檔
- private void btnWriteXML_Click(object sender, EventArgs e)
- {
- ds.WriteXml("http://www.cnblogs.com/New.xml");
- ds.WriteXml("http://www.cnblogs.com/New_Alter.xml", XmlWriteMode.DiffGram);
- }
- //加載Schema給DataSet
- private void btnReadXmlSchema_Click(object sender, EventArgs e)
- {
- DataSet newDataSet = new DataSet();
- newDataSet.ReadXmlSchema("http://www.cnblogs.com/Customer.xsd");
- dataGridView1.DataSource = newDataSet.Tables[0];
- }
- //將DataSet的Schema寫出
- private void btnWriteXmlSchema_Click(object sender, EventArgs e)
- {
- DataSet newDataSet = new DataSet();
- DataTable dt = new DataTable();
- DataColumn dc1 = new DataColumn("id", typeof(int));
- DataColumn dc2 = new DataColumn("name", typeof(string));
- dt.Columns.Add(dc1);
- dt.Columns.Add(dc2);
- newDataSet.Tables.Add(dt);
- dataGridView1.DataSource = newDataSet;
- dataGridView1.DataMember = "Table1";
- newDataSet.WriteXmlSchema("http://www.cnblogs.com/newSchema.xsd");
- }
- //GetXml()方法的使用
- private void btnGetXml_Click(object sender, EventArgs e)
- {
- DataSet newXml = new DataSet();
- newXml.ReadXml("http://www.cnblogs.com/" + "Person.xml");
- dataGridView1.DataSource = newXml.Tables[0];
- //GetXml():返回DataSet中XML形式的字符串
- string strXml = newXml.GetXml();
- textBox1.Text = strXml;
- }
- //GetXmlSchema()方法的使用
- private void btnGetXmlSchema_Click(object sender, EventArgs e)
- {
- /* 注意:
- 如果DataSet已經(jīng)擁有一個Schema模式,
- 再加載新的Schema模式文件,
- 則會自動將兩個Schema模式合并。
- */
- DataSet newSchema = new DataSet();
- newSchema.ReadXmlSchema("http://www.cnblogs.com/Customer.xsd");
- dataGridView1.DataSource = newSchema.Tables[0];
- //GetXmlSchema():返回DataSet所使用的Schema模式文件的字符串
- string strSchema = newSchema.GetXmlSchema();
- textBox1.Text = strSchema;
- }
- }
- }
Winform 程序的界面效果如下:
原文標(biāo)題:XML 與DataSet 對象的關(guān)系
鏈接:http://www.cnblogs.com/xugang/archive/2010/09/16/1827988.html
【編輯推薦】


2010-01-04 09:40:46
2012-04-13 10:45:59




