一起谈.NET技术,XML与DataSet对象的关系

简介:   在.NET Framework 中,经常使用XML 作为存储和传输各种数据的格式。DataSet 中的数据可以转换成XML 的形式来表示和存储。我们可以使用XML 对象同步和转换DataSet 的数据,而DataSet 也可以存储和传输XML 格式的数据。

  在.NET Framework 中,经常使用XML 作为存储和传输各种数据的格式。DataSet 中的数据可以转换成XML 的形式来表示和存储。我们可以使用XML 对象同步和转换DataSet 的数据,而DataSet 也可以存储和传输XML 格式的数据。

  XML 与 DataSet 的关系如下图所示:

XmlDataDocument_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 程序的界面效果如下:

Winform 程序的界面效果图  源码下载

目录
相关文章
|
21天前
|
SQL 小程序 API
如何运用C#.NET技术快速开发一套掌上医院系统?
本方案基于C#.NET技术快速构建掌上医院系统,结合模块化开发理念与医院信息化需求。核心功能涵盖用户端的预约挂号、在线问诊、报告查询等,以及管理端的排班管理和数据统计。采用.NET Core Web API与uni-app实现前后端分离,支持跨平台小程序开发。数据库选用SQL Server 2012,并通过读写分离与索引优化提升性能。部署方案包括Windows Server与负载均衡设计,确保高可用性。同时针对API差异、数据库老化及高并发等问题制定应对措施,保障系统稳定运行。推荐使用Postman、Redgate等工具辅助开发,提升效率与质量。
|
4月前
|
开发框架 算法 .NET
C#/.NET/.NET Core技术前沿周刊 | 第 15 期(2024年11.25-11.30)
C#/.NET/.NET Core技术前沿周刊 | 第 15 期(2024年11.25-11.30)
|
4月前
|
开发框架 Cloud Native .NET
C#/.NET/.NET Core技术前沿周刊 | 第 16 期(2024年12.01-12.08)
C#/.NET/.NET Core技术前沿周刊 | 第 16 期(2024年12.01-12.08)
|
5月前
|
自然语言处理 物联网 图形学
.NET 技术凭借其独特的优势和特性,为开发者们提供了一种高效、可靠且富有创造力的开发体验
本文深入探讨了.NET技术的独特优势及其在多个领域的应用,包括企业级应用、Web应用、桌面应用、移动应用和游戏开发。通过强大的工具集、高效的代码管理、跨平台支持及稳定的性能,.NET为开发者提供了高效、可靠的开发体验,并面对技术更新和竞争压力,不断创新发展。
221 7
|
5月前
|
开发框架 安全 .NET
在数字化时代,.NET 技术凭借跨平台兼容性、丰富的开发工具和框架、高效的性能及强大的安全稳定性,成为软件开发的重要支柱
在数字化时代,.NET 技术凭借跨平台兼容性、丰富的开发工具和框架、高效的性能及强大的安全稳定性,成为软件开发的重要支柱。它不仅加速了应用开发进程,提升了开发质量和可靠性,还促进了创新和业务发展,培养了专业人才和技术社区,为软件开发和数字化转型做出了重要贡献。
84 5
|
5月前
|
传感器 人工智能 供应链
.NET开发技术在数字化时代的创新作用,从高效的开发环境、强大的性能表现、丰富的库和框架资源等方面揭示了其关键优势。
本文深入探讨了.NET开发技术在数字化时代的创新作用,从高效的开发环境、强大的性能表现、丰富的库和框架资源等方面揭示了其关键优势。通过企业级应用、Web应用及移动应用的创新案例,展示了.NET在各领域的广泛应用和巨大潜力。展望未来,.NET将与新兴技术深度融合,拓展跨平台开发,推动云原生应用发展,持续创新。
70 4
|
5月前
|
开发框架 .NET C#
.NET 技术凭借高效开发环境、强大框架支持及跨平台特性,在软件开发中占据重要地位
.NET 技术凭借高效开发环境、强大框架支持及跨平台特性,在软件开发中占据重要地位。从企业应用到电子商务,再到移动开发,.NET 均展现出卓越性能,助力开发者提升效率与项目质量,推动行业持续发展。
89 4
|
5月前
|
机器学习/深度学习 人工智能 Cloud Native
在数字化时代,.NET 技术凭借其跨平台兼容性、丰富的类库和工具集以及卓越的性能与效率,成为软件开发的重要平台
在数字化时代,.NET 技术凭借其跨平台兼容性、丰富的类库和工具集以及卓越的性能与效率,成为软件开发的重要平台。本文深入解析 .NET 的核心优势,探讨其在企业级应用、Web 开发及移动应用等领域的应用案例,并展望未来在人工智能、云原生等方面的发展趋势。
89 3
|
5月前
|
敏捷开发 缓存 中间件
.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素
本文深入探讨了.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素,并通过企业级应用和Web应用开发的实践案例,展示了如何在实际项目中应用这些模式,旨在为开发者提供有益的参考和指导。
67 3
|
5月前
|
开发框架 安全 Java
.NET技术的独特魅力与优势,涵盖高效的开发体验、强大的性能表现、高度的可扩展性及丰富的生态系统等方面,展示了其在软件开发领域的核心竞争力
本文深入探讨了.NET技术的独特魅力与优势,涵盖高效的开发体验、强大的性能表现、高度的可扩展性及丰富的生态系统等方面,展示了其在软件开发领域的核心竞争力。.NET不仅支持跨平台开发,具备出色的安全性和稳定性,还能与多种技术无缝集成,为企业级应用提供全面支持。
145 3

相关课程

更多