ReadXml 提供了只将数据或同时将数据和架构从 XML 文档读入 DataSet 的方式(若要同时读数据和架构,请使用包括 mode 参数的 ReadXML 重载之一,并将其值设置为 ReadSchema)。ReadXmlSchema 方法仅读架构。

对于 WriteXml 和 WriteXmlSchema 方法也是如此。若要写入来自 DataSet 的 XML 数据或架构和数据两者,使用 WriteXml 方法。若要只写入架构,请使用 WriteXmlSchema 方法。

XML 数据可直接从文件、Stream 对象、XmlWriter 对象或 TextWriter 对象中读取。可以根据需要使用 ReadXml 的两组重载方法中的一组。第一组中的四个重载方法只取一个参数。第二组中的四个重载方法除了取第一组中的一个参数外另外多取了一个参数 (XmlReadMode)。

1、ReadXml 方法的重载形式

DataSet.ReadXml (Stream)           使用指定的 System.IO.Stream 将 XML 架构和数据读入 DataSet。

DataSet.ReadXml (String)            使用指定的文件将 XML 架构和数据读入 DataSet。

DataSet.ReadXml (TextReader)    使用指定的 System.IO.TextReader 将 XML 架构和数据读入 DataSet。

DataSet.ReadXml (XmlReader)     使用指定的 System.Xml.XmlReader 将 XML 架构和数据读入 DataSet。

DataSet.ReadXml (Stream, XmlReadMode)   使用指定的 System.IO.Stream 和 XmlReadMode 将 XML 架构和数据读入DataSet。

DataSet.ReadXml (String, XmlReadMode)     使用指定的文件和 XmlReadMode 将 XML 架构和数据读入 DataSet。

DataSet.ReadXml (TextReader, XmlReadMode)    使用指定的 System.IO.TextReader 和 XmlReadMode 将 XML 架构和数据读入DataSet。

DataSet.ReadXml (XmlReader, XmlReadMode)  使用指定的 System.Xml.XmlReader 和 XmlReadMode 将 XML 架构和数据读入DataSet。

2、ReadXml 方法的重载形式

WriteXml(Stream)    使用指定的 System.IO.Stream 为 DataSet 写当前数据。

WriteXml(TextWriter)   使用指定的 TextWriter 为 DataSet 写当前数据。

WriteXml(String)    将 DataSet 的当前数据写入指定的文件。

WriteXml(XmlWriter)    将 DataSet 的当前数据写入指定的 XmlWriter。

WriteXml(Stream, XmlWriteMode)   使用指定的 System.IO.Stream 和 XmlWriteMode 为 DataSet 写当前数据,还可以选择写架构。若要写架构,请将 mode 参数的值设置为 WriteSchema。

WriteXml(TextWriter, XmlWriteMode)  使用指定的 TextWriter 和 XmlWriteMode 为 DataSet 写当前数据,还可以选择写架构。若要写架构,请将 mode 参数的值设置为 WriteSchema。

WriteXml(String, XmlWriteMode)  使用指定的 XmlWriteMode 将 DataSet 的当前数据写入指定的文件,还可以选择将架构写入指定的文件。若要写架构,请将 mode 参数的值设置为 WriteSchema。

WriteXml(XmlWriter, XmlWriteMode)   使用指定的 XmlWriter 和 XmlWriteMode 为 DataSet 写当前数据,还可以选择写架构。若要写架构,请将 mode 参数的值设置为 WriteSchema。

3、注意点

(1)如果指定内联架构,则该内联架构用于在加载数据之前扩展现有的关系结构。如果存在任何冲突(例如,用不同的数据类型定义了同一个表中的同一列),将引发异常。

(2)如果未指定内联架构,则在必要时按照 XML 文档的结构通过推理扩展关系结构。如果不能通过推理扩展架构以公开所有数据,则将引发异常。

(3)如果 DataSet 的 XML 架构包含 targetNamespace,则可能无法读取数据,并且在调用 ReadXml 以加载 XML 中包含具有无限定命名空间的元素的DataSet 时,可能会发生异常。若要读取非限定元素,请按下例的演示,在 XML 架构中将 elementFormDefault 设置为“qualified”。

<xsd:schema id="MyDataSet"

elementFormDefault="qualified"

targetNamespace="http://www.tempuri.org/MyDataSet.xsd"

xmlns="http://www.tempuri.org/MyDataSet.xsd"

xmlns:xsd="http://www.w3.org/2001/XMLSchema"

xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">

</xsd:schema>

(4)如果 DataSet 的架构包含同一命名空间中同名但类型不同的元素,则当您尝试通过指定 XmlReadMode.ReadSchema 将该架构读入具有ReadXml 的 DataSet 时,将发生异常

4、实例:

(1)WriteXml()

using System;

using System.Collections.Generic;

using System.Text;

using System.Data.SqlClient;

using System.Data;

namespace sqlconnection1

{

class Program

{

private void SQLConnectionF(string source, string select)

{

//创建连接

SqlConnection con = new SqlConnection(source);

SqlDataAdapter adapt = new SqlDataAdapter(select, con);

try

{

con.Open();

Console.WriteLine("connection is successful!");

}

catch (Exception e)

{

Console.WriteLine("connection error is :{0}", e.ToString());

}

//创建DataSet

DataSet ds = new DataSet();

//将数据添加到DataSet中

adapt.Fill(ds, "mytest");

ds.WriteXml(@"e:\mytest.xml");

Console.ReadLine();

con.Close();

}

static void Main(string[] args)

{

string sou = "server=duanyf\\SQLEXPRESS;" + "Initial Catalog=master;" + "UID = sa;" + "Password = dyf123";

string sel = "SELECT name,number,low,high From dbo.spt_values";

Program sqlcon = new Program();

sqlcon.SQLConnectionF(sou, sel);

}

}

}

(2)ReadXml()

using System;

using System.Collections.Generic;

using System.Text;

using System.Data.SqlClient;

using System.Data;

namespace sqlconnection1

{

class Program

{

static void Main(string[] args)

{

DataSet dsxml = new DataSet();

dsxml.ReadXml(@"e:\mytest.xml");

Console.WriteLine("{0,-20} {1,-15}{2,-10}{3,-10}",dsxml.Tables[0].Columns[0],dsxml.Tables[0].Columns[1],

dsxml.Tables [0].Columns [2],dsxml .Tables[0].Columns[3]);

foreach (DataRow row in dsxml.Tables[0].Rows)

{

Console.WriteLine("{0,-20} {1,-15}{2,-10}{3,-10}",row[0],row[1],row[2],row[3]);

}

Console.ReadLine();

}

}

}

转载于:https://www.cnblogs.com/janeaiai/p/4867826.html

DataSet用法操作xml相关推荐

  1. DataSet用法详细

    DataSet用法详细 一.特点介绍 1.处理脱机数据,在多层应用程序中很有用. 2.可以在任何时候查看DataSet中任意行的内容,允许修改查询结果的方法. 3.处理分级数据 4.缓存更改 5.XM ...

  2. .net操作xml小结 (转)

    .net操作xml小结 一.简单介绍 using System.Xml; //初始化一个xml实例 XmlDocument xml=new XmlDocument(); //导入指定xml文件 xml ...

  3. 我错了,有个叫 SelectSingleNode 的可以操作 xml

    我错了,有个叫 SelectSingleNode 的可以操作 xml http://blog.csdn.net/wf520pb/article/details/2644549 ------------ ...

  4. Repeater、GridView等 操作XML

    Repeater.GridView等 操作XML文件 在项目中需要对XML文件进行管理,我用了Repeater 的方式来实现了实时的更新 希望对阅读这篇随笔的您有所帮助,我用的Repeater,您也可 ...

  5. Dom4j操作XML

    dom4j帮助文档在dom4j-1.6.1/docs/guide.html文件里面,全部是英文,但是基本上应该能看懂. 1.  四种操作xml的方式:SAX,DOM,JDOM,DOM4J. 2.  D ...

  6. 操作xml文档的常用方式

    1.操作XML文档的两种常用方式: 1)使用XmlReader类和XmlWriter类操作 XmlReader是基于数据流的,占用极少的内存,是只读方式的,所以速度极快.只能采用遍历的模式查找数据节点 ...

  7. jdom操作xml实战

    文章目录 基本用法 实战 引入jar包 工具类xmlutil: 业务代码: 查看效果: 最近有个项目用到了xml的写入,其实目前java有很多的方式操作xml,比如之前用到的dom4j,今天推荐个更好 ...

  8. Qt操作XML文件(创建,读,写,修改,添加,删除)

    XML文件在项目开发的过程中经常用的,比如配置文件基本上都是XML格式的,本文介绍在Qt环境下操作XML文件,具体用法看代码 原txt文件内容,在 http://www1.jctrans.com/to ...

  9. Asp.Net 操作XML文件的增删改查 利用GridView

    不废话,直接上如何利用Asp.NET操作XML文件,并对其属性进行修改,刚开始的时候,是打算使用JS来控制生成XML文件的,但是最后却是无法创建文件,读取文件则没有使用了 index.aspx 文件 ...

  10. ADO.NET系列之操作XML

    如题,我们保存数据的方式有很多种.在ASP.NET中,可以通过js赋值隐藏域的方式,也可以通过ViewState,Session这样的内置对象,还可以通过数据库的形式.现在经常用到的就是XML了,它的 ...

最新文章

  1. python正则表达式提取数字比较好_python正则表达式从字符串中提取数字的思路详解...
  2. python编程100例画图-Python练习实例56 | 画图,学用circle画圆形
  3. 零基础代码学python-零基础学Python 超详细教程
  4. 您应该知道的6个物联网术语—Vecloud微云
  5. P3899 [湖南集训]更为厉害(线段树合并、长链剖分、二维数点)
  6. 原创-linux下编译器vi、vim的使用技巧
  7. 特斯拉=车祸多?马斯克回击
  8. 2019APMCM亚太数学建模题目
  9. 知识关联视角下金融证券知识图谱构建与相关股票发现
  10. iphonex适配游戏_Unity+iPhoneX适配方案
  11. 代码题--C++--小米--英文句子字符串反转
  12. SOLIDWORKS凸台拉伸命令,你真的会用吗?
  13. 制作openstack离线 yum 源
  14. 对越Altium Designer 17.0.9电路设计软件
  15. 【历史上的今天】8 月 26 日:jQuery 发布;中国第一台百万次计算机试制成功
  16. 阿里云弹性EIP和固定公网IP的区别
  17. 阿里高层大调整,集团CEO张勇兼任阿里云总裁,CTO鲁肃卸任
  18. CE认证CLASS A和CLASS B的区别
  19. mysql用天兔监测什么_天兔监控服务器和mysql,redis等监控
  20. 关于专利书写以及申报的一点心得体会

热门文章

  1. 需求文档、需求分析报告、需求规格说明书分析
  2. Vue-cli3 ,js根据汉字或拼音模糊搜索功能,汉字支持同音字、多音字,支持首字母
  3. (QT学习笔记):QListWidget、QTreeWidget、 QTableWidget的基本使用
  4. 《深入浅出MFC》读书笔记
  5. 模拟集成电路设计初学系列
  6. 【计算机二级】公共基础知识总结
  7. 百度文库文章提取器(下)
  8. Eaplayer漂亮好用的wordpress音乐播放器插件
  9. 常用的4种黑盒测试方法
  10. Microsoft® Silverlight™ Streaming by Windows Live™