dataset 用法(1)

DataSet是表和列结构在内存中的表示方式,DataSet支持多表、表间关系、数据约束等,和关系数据库的模型基本一致。(本质上是微型的数据库。包含一组DataTable对象和DataTable之间的连接关系。不包含数据库连接的概念,也就是说其中的数据可以不是来自数据库,可以是读取的文件中的数据。DataTable包含一些DataRow和DataColumn表示数据库表中的行和列,通过他们可以获取表、行和列的元素,且支持主键和外键。

DataSet的数据集是与数据库断开的,DataSet中可包括多个DataTable(可将多个查询结构存到一个DataSet中)。而DataTable中又包括多个DataRow、DataColumn,可通过DataRow、DataColumn来查看、操作其中的数据。如果要将操作后的结果集返回给数据库,则用DataAdapter的Update方法。

DataSet 可将数据和架构作为 XML 文档进行读写。可使用 WriteXmlSchema
方法将架构保存为 XML 架构,并且可以使用 WriteXml 方法保存架构和数据。若要读取既包含架构也包含数据的 XML 文档,请使用 ReadXml
方法。

1、DataSet的特点

(1)DataSet中的数据集是脱机的。

(2)DataSet中的数据集可以在任何时候去读取或修改。

(3)DataSet中中的 DataTable 对象是按条件区分大小写的。(例如,如果一个 DataTable
被命名为“mydatatable”,另一个被命名为“Mydatatable”,则用于搜索其中一个表的字符串被认为是区分大小写的。但是,如果“mydatatable”存在而“Mydatatable”不存在,则认为该搜索字符串不区分大小写)。

(4)典型的多层实现中,创建和刷新 DataSet 并依次更新原始数据的步骤:

A:通过 DataAdapter 使用数据源中的数据生成和填充 DataSet 中的每个
DataTable。

B:通过添加、更新或删除 DataRow 对象更改单个 DataTable 对象中的数据。

C:调用 GetChanges 方法以创建只反映对数据进行的更改的第二个 DataSet。

D:调用 DataAdapter 的 Update 方法,并将第二个 DataSet 作为参数传递。

E:调用 Merge 方法将第二个 DataSet 中的更改合并到第一个中。

F:针对 DataSet 调用 AcceptChanges。或者,调用 RejectChanges
以取消更改。

2、常用属性

CaseSensitive:用于控制DataTable中的字符串比较是否区分大小写。

DataSetName:当前DataSet的名称。如果不指定,则该属性值设置为"NewDataSet"。如果将DataSet内容写入XML文件,DataSetName是XML文件的根节点名称。

DesignMode:如果在设计时使用组件中的DataSet,DesignMode返回True,否则返回False。

HasErrors:表示DataSet中的DataRow对象是否包含错误。如果将一批更改提交给数据库并将DataAdapter对象的ContinueUpdateOnError属性设置为True,则在提交更改后必须检查DataSet的HasErrors属性,以确定是否有更新失败。

NameSpace和Prefix:指定XML命名空间和前缀

Relations:返回一个DataRelationCollection对象。

Tables:Tables:获取包含在 DataSet
中的表的集合。通过索引访问DataTable有更好的性能。

DefaultViewManager:获取 DataSet 所包含的数据的自定义视图,以允许使用自定义的
DataViewManager 进行筛选、搜索和导航。

Events:获取附加到该组件的事件处理程序的列表。

Namespace:获取或设置 DataSet 的命名空间。

Prefix:获取或设置一个 XML 前缀,该前缀是 DataSet 的命名空间的别名。

Relations:获取用于将表链接起来并允许从父表浏览到子表的关系的集合。

3、方法

AcceptChanges:提交自加载此 DataSet 或上次调用 AcceptChanges 以来对其进行的所有更改。

BeginInit:开始初始化在窗体上使用或由另一个组件使用的 DataSet。初始化发生在运行时。

Clear:通过移除所有表中的所有行来清除任何数据的 DataSet。

Clone:复制 DataSet 的结构,包括所有 DataTable 架构、关系和约束。不要复制任何数据。

Copy:复制该 DataSet 的结构和数据。

CreateDataReader: 为每个 DataTable 返回带有一个结果集的 DataTableReader,顺序与 Tables
集合中表的显示顺序相同。

EndInit:结束在窗体上使用或由另一个组件使用的 DataSet 的初始化。初始化发生在运行时。

Equals:确定指定的 Object 是否等于当前的 Object。

GetChanges: 获取 DataSet 的副本,该副本包含自上次加载以来或自调用 AcceptChanges
以来对该数据集进行的所有更改。

GetType:获取当前实例的 Type。

GetXml:返回存储在 DataSet 中的数据的 XML 表示形式。

GetXmlSchema:返回存储在 DataSet 中的数据的 XML 表示形式的 XML 架构。

HasChanges:该值指示 DataSet 是否有更改,包括新增行、已删除的行或已修改的行。

InferXmlSchema:将 XML 架构应用于 DataSet。

Load: 通过所提供的 IDataReader,用某个数据源的值填充 DataSet。

Merge:将指定的 DataSet、DataTable 或 DataRow 对象的数组合并到当前的 DataSet 或DataTable
中。

OnRemoveRelation:当从 DataTable 中移除 DataRelation 对象时发生。

OnRemoveTable:当从 DataSet 中移除 DataTable 时发生。

ReadXml: 将 XML 架构和数据读入 DataSet。

ReadXmlSchema: 将 XML 架构读入 DataSet。

RejectChanges:回滚自创建 DataSet 以来或上次调用 DataSet.AcceptChanges
以来对其进行的所有更改。

Reset:将 DataSet 重置为其初始状态。子类应重写 Reset,以便将 DataSet 还原到其原始状态。

WriteXml: 从 DataSet 写 XML 数据,还可以选择写架构。

WriteXmlSchema: 写 XML 架构形式的 DataSet 结构。

4、事件

Disposed:添加事件处理程序以侦听组件上的 Disposed 事件。

Initialized:初始化 DataSet 后发生。

MergeFailed:当目标和源 DataRow 的主键值相同且 EnforceConstraints 设置为真时发生。

【转自】http://www.cnblogs.com/hulang/archive/2011/01/11/1932563.html

dataset 用法(1),布布扣,bubuko.com

时间: 2024-10-10 08:32:14

dataset 用法(1)的相关文章

dataset 用法(2)

1.为DataTable添加列 (1)添加列 DataTable  tbl = ds.Tables.Add("User"); DataColumn col =tbl.Columns.Add("UserID",typeof(int)); col.AllowDBNull = false; col.MaxLength = 6; col.Unique = true; tbl.PrimaryKey = new DataColumn[]{tbl.Columns["Us

DataSet用法详细 转

一.特点介绍 1.处理脱机数据,在多层应用程序中很有用.2.可以在任何时候查看DataSet中任意行的内容,允许修改查询结果的方法.3.处理分级数据4.缓存更改5.XML的完整性:DataSet对象和XML文档几乎是可互换的. 二.使用介绍 1.创建DataSet对象: DataSetds = new DataSet("DataSetName"); 2.查看调用SqlDataAdapter.Fill创建的结构 da.Fill(ds,"Orders"); DataTa

dataset 用法(3)

ReadXml 提供了只将数据或同时将数据和架构从 XML 文档读入 DataSet 的方式(若要同时读数据和架构,请使用包括 mode 参数的 ReadXML 重载之一,并将其值设置为 ReadSchema).ReadXmlSchema 方法仅读架构. 对于 WriteXml 和 WriteXmlSchema 方法也是如此.若要写入来自 DataSet 的 XML 数据或架构和数据两者,使用 WriteXml 方法.若要只写入架构,请使用 WriteXmlSchema 方法. XML 数据可直

DATASET()用法

DataSet是ADO.NET的中心概念.可以把DataSet当成内存中的数据库,DataSet是不依赖于数据库的独立数据集合.所谓独立,就是说,即使断开数据链路,或者关闭数据库,DataSet依然是可用的,DataSet在内部是用XML来描述数据的,由于XML是一种与平台无关.与语言无关的数据描述语言,而且可以描述复杂关系的数据,比如父子关系的数据,所以DataSet实际上可以容纳具有复杂关系的数据,而且不再依赖于数据库链路. 在典型的多层实现中,用于创建和刷新 DataSet 并依次更新原始

关于DataSet事务处理以及SqlDataAdapter四种用法

如果是直接执行SQL语句时,事务很好处理,对于大多数的Erp应用,不能能用SQL来处理数据,所以更新DataSet更为常用,更新单个的DataSet也非常简单,不需要事务的处理,给多个DataSet增加事务多数应用于分布式的程序代码中,下面为在Webservice中更新Winform传递过来的经过压缩的数据集的事务处理代码,多个DataSet 情况. /// <summary> /// 更新经过压缩的DataSet /// </summary> /// <param >

C#里sqlDataAdapter.fill(DataSet,String)的用法

第二个参数 String是指定DataSet 里表的名字,例如 sqlDataAdapter.fill(DataSet,"学生表") 指定后,以后就可以这样调用这张表 DataSet.Tables["学生表"] 第二个参数可以不要的,如果不要第二个参数 String 那你调用这张表只能通过索引号,例如 DataSet.Tables[0] 如果填充的表比较多的话,用这个参数比较容易管理和调用. C#里sqlDataAdapter.fill(DataSet,String

DataSet与DataTable基本用法

http://files.cnblogs.com/files/monkeyZhong/DataSetExample.rar 在设计数据库操作或者XML操作等表格数据时,我们难免要跟DataSet和DataTable打交道,我们这里就介绍下这几个类的用法: 首先介绍DataTable,其实就是一个二维表格,没那么悬乎,举个构造的例子: DataTable dt = new DataTable("Customers"); dt.Columns.Add("CustomerID&qu

C# DataSet与DataTable的区别和用法

DataSet是数据集,DataTable是数据表,DataSet存储多个DataTable.DataSet和DataTable像是专门存储数据的一个容器,在你查询数据库得到一些结果时可以存在里面. DataSet功能强大有浏览.排序.搜索.过滤.处理分级数据.缓存更改等功能,还可以与XML数据互换.DataSet中可包括多个DataTable,可将多个查询结构存到一个DataSet中,方便操作 ADO.NET开发人员为方便数据处理开发出来的,是数据的集合,为解决DataReader的缺陷设计的

C# DataSet的基本用法

  首先我们需要打开一个联结: string MyConnString = "Driver={Microsoft Access Driver (*.mdb)}; DBQ=c:/test/test.mdb;"; string strComm = "select * from UserList"; ADOConnection MyConnection = new ADOConnection(MyConnString); ADODataSetCommand MyComm