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

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

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

XML 与 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 文件如下:

<?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文档的数据到DataSet
        private void btnReadXML_Click(object sender, EventArgs e)
        {
            ds.ReadXml("http://www.cnblogs.com/" + "Person.xml");
            dataGridView1.DataSource = ds.Tables[0];
        }
 
        //将DataSet中的数据写出到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已经拥有一个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 程序的界面效果如下:

转载于:https://www.cnblogs.com/30ErLi/archive/2010/09/16/1828040.html

XML 与DataSet 对象的关系相关推荐

  1. 数据库-ADONET-在数据集DataSet中使用关系对象DataRelation处理关系

    处理关系数据 数据库中,表很少是独立结构的,大部分数据库都包含相互关联的表. 在构建应用程序时,会遇到--显示或者通过程序设计访问数据库中相关表的数据的情况. 用户会希望,能通过在不同的表之间定位,来 ...

  2. 深入分析ADO.NET中的DataSet对象

    ADO.NET是.net Framework SDK中用以操作数据库的类库的总称.而DataSet类则是ADO.NET中最核心的成员之一,也是各种开发基于.Net平台程序语言开发数据库应用程序最常接触 ...

  3. XML与DataSet的相互转换类

    送给大家一个XML与DataSet的相互转换的类: XmlDatasetConvert 该类提供了四种方法: 1.将xml对象内容字符串转换为DataSet 2.将xml文件转换为DataSet 3. ...

  4. 浅谈ASP.net中的DataSet对象

    在我们对数据库进行操作的时候,总是先把数据从数据库取出来,然后放到一个"容器"中,再通过这个"容器"取出数据显示在前台,而充当这种容器的角色中当属DataSet ...

  5. XML与DataSet的相互转换

    from:http://www.cnblogs.com/guoerzzf/archive/2009/04/09/1432668.html XmlDatasetConvert 该类提供了四种方法: 1. ...

  6. iBatis.Net实现返回DataTable和DataSet对象

    如题.要返回一个ADO.NET对象好像没有使用ORM的必要,而且从编程的角度看这样的实现一点也不OO,但是实际的开发场景中还是会碰到这种需求的.下面我就借鉴前人的经验,结合实际的示例,再总结一下.如果 ...

  7. 使用XStream将JSON转换为XML到Java对象

    XStream库可以是将JSON从Java转换为XML来回转换的有效工具. 让我们逐一探究它们中的每一个,并查看使用了哪个驱动程序. 处理JSON 要将JSON转换为Java对象,您要做的就是使用适当 ...

  8. Hibernate对象与对象的关系

    hibernate对象与对象的关系,其实是对象与表的关系. 一.一对一 比如一个人对应一张身份证,一个门对应一把钥匙等- 在数据库中两张表,一张表的主键是通过引入另一张表的主键,建外键的关系 card ...

  9. 玩转肺癌目标检测数据集Lung-PET-CT-Dx ——③整理、验证数据,建立Dataset对象

    文章目录 数据整理 整理出所有的dcm文件 整理出所有的xml标注文件 整理数据①--舍弃错误的标注文件 整理数据②--两个标注文件指向同一个目标图片的情况 封装函数,传入xml文件,显示标注效果 整 ...

最新文章

  1. 异常The Struts dispatcher cannot be found. This is
  2. 【杂项】CUDA下找不到CUDA Sample文件
  3. ACCESS在哪输入SQL语句
  4. git 创建webpack项目_Webpack入门:从安装到配置
  5. 杭电的题,输出格式卡的很严。HDU 1716 排列2
  6. vs无法写入量的大数据_一个每天服务数万人的企业食堂:自助餐按重计价,大数据支持食材预备量...
  7. Lintcode--6(767)--翻转数组
  8. 数据交互智能终端设想
  9. python3.4学习笔记(二十一) python实现指定字符串补全空格、前面填充0的方法
  10. tar命令--解压缩
  11. ALSA声卡10_从零编写之数据传输_学习笔记
  12. bit加密的时候会格式化硬盘吗_硬件百科:能在移动SSD上装系统吗?
  13. mysql配置后无法在dos里运行
  14. python中文词云图代码_用python写一个词云图生成器
  15. 工作经验分享|你在工作中应该注意什么?
  16. ESP8266 NodeMCU驱动OLED屏(SSD1306,4PIN,IIC)
  17. 记录踩过的坑-WPS文字
  18. groovy if 判断字符串_Groovy语法
  19. 微信与朋友圈后台架构
  20. vscode运行python没有结果输出

热门文章

  1. matlab在图像上画出来的矩形框如何变成可托动的_计算机基础系列:源代码如何被计算机执行...
  2. python去重txt文本_Python 文件去重(转载)
  3. 幅度响应怎么计算_广播百科 频率响应
  4. 池州市计算机专科,2021年3月安徽省池州市计算机等级考试时间
  5. java mybatis enum_mybatis处理枚举类的简单方法
  6. python面试题之“该死的for循环系列”(二)
  7. 到底该如何理解DevOps这个词
  8. mySql比较并获取当前时间x分钟之前的数据(时间是字符串类型)
  9. 学习Key与Value的集合hashtable
  10. MongoDB之bson的介绍