XML與DataSet對(duì)象的關(guān)系是什么

本篇文章給大家分享的是有關(guān)XML與DataSet對(duì)象的關(guān)系是什么,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

創(chuàng)新互聯(lián)主營(yíng)勐臘網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,重慶APP開(kāi)發(fā)公司,勐臘h5小程序設(shè)計(jì)搭建,勐臘網(wǎng)站營(yíng)銷(xiāo)推廣歡迎勐臘等地區(qū)企業(yè)咨詢

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

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

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

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

XML與DataSet對(duì)象的關(guān)系是什么

DataSet 對(duì)象的常用方法如下:

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

B.  使用WriteXml( ) 方法:將DataSet 對(duì)象中的數(shù)據(jù)以XML 格式寫(xiě)出到文件或流中。DataSet 對(duì)象.WriteXml( 文件路徑字符串| stream 對(duì)象, XmlWriteMode 枚舉值[可以省略] ) ;

C.  使用ReadXmlSchema( ) 方法:將Shema 模式文件讀入DataSet 對(duì)象。DataSet 對(duì)象.ReadXmlSchema( Stream | FileName | TextReader | XmlReader ) ;

D.  使用WriteXmlSchema( ) 方法:將DataSet 對(duì)象的Shema 模式文件寫(xiě)出到文件或流。DataSet 對(duì)象.WriteXmlSchema( Stream | FileName | TextWriter | XmlWriter ) ;

E.  使用GetXmlSchema( ) 方法:將DataSet 對(duì)象的Shema 模式,以字符串的形式獲得。DataSet 對(duì)象.GetXmlSchema( );

F.  使用GetXml( ) 方法:將DataSet 對(duì)象的XML 格式的數(shù)據(jù)集,以字符串的形式獲得。DataSet 對(duì)象.GetXml( );

接下來(lái),通過(guò)一個(gè)綜合示例進(jìn)行演示。

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ù)寫(xiě)出到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寫(xiě)出           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)擁有一個(gè)Schema模式,                   再加載新的Schema模式文件,                   則會(huì)自動(dòng)將兩個(gè)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 程序的界面效果如下:

XML與DataSet對(duì)象的關(guān)系是什么

以上就是XML與DataSet對(duì)象的關(guān)系是什么,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

當(dāng)前標(biāo)題:XML與DataSet對(duì)象的關(guān)系是什么
網(wǎng)站網(wǎng)址:http://muchs.cn/article38/jpgosp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)、外貿(mào)網(wǎng)站建設(shè)定制網(wǎng)站、網(wǎng)站營(yíng)銷(xiāo)、自適應(yīng)網(wǎng)站軟件開(kāi)發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)