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)的更多相关文章
-
DataSet用法详细 转
DataSet用法详细 转 DataSet用法详细 一.特点介绍 1.处理脱机数据,在多层应用程序中很有用. 2.可以在任何时候查看DataSet中任意行的内容,允许修改查询结果的方法. 3.处理分级 ...
-
DataSet用法详细
转自:http://www.cnblogs.com/zeroone/archive/2012/06/08/2541299.html DataSet用法详细 一.特点介绍 1.处理脱机数据,在多层应用程 ...
-
dataset 用法(3)
ReadXml 提供了只将数据或同时将数据和架构从 XML 文档读入 DataSet 的方式(若要同时读数据和架构,请使用包括 mode 参数的 ReadXML 重载之一,并将其值设置为 ReadSc ...
-
dataset 用法(2)
1.为DataTable添加列 (1)添加列 DataTable tbl = ds.Tables.Add("User"); DataColumn col =tbl.Columns ...
-
DATASET()用法
DataSet是ADO.NET的中心概念.可以把DataSet当成内存中的数据库,DataSet是不依赖于数据库的独立数据集合.所谓独立,就是说,即使断开数据链路,或者关闭数据库,DataSet依然是 ...
-
js 控制 class 类名(classList) 和 自定义属性(dataset)
classList 用法: const div = document.querySelector('div') div.classList.add('myclass') // 添加类名 div.cla ...
-
tensorflow学习笔记--dataset使用,创建自己的数据集
数据读入需求 我们在训练模型参数时想要从训练数据集中一次取出一小批数据(比如50条.100条)做梯度下降,不断地分批取出数据直到损失函数基本不再减小并且在训练集上的正确率足够高,取出的n条数据还要是预 ...
-
【转】如何在TensorFlow中高效使用数据集
本文主要记录tensorflow一个比较好用的API:Dataset,feed-dict 是向 TensorFlow 传递信息最慢的方式,应该尽量避免使用.向模型提供数据的正确方式是使用输入管道,这样 ...
-
dataset 和DataTable的用法
以下包含了这两种不同属性的用法: foreach (DataRow dr in dataset.Tables[0].Rows) { if (i != 0 && l ...
随机推荐
-
CodeVS 2845 排序的代价
Description 给你一个数列使他递增,交换两个元素的代价为两个数的和,最小化代价. Sol 置换群+离散化. 使一个数列恢复递增顺序,那么,他和他要到达的位置的数需要交换,这样就形成了一个置换 ...
-
shiro 简单的身份验证 案例
Apache Shiro是Java的一个安全框架,Shiro可以帮助我们完成:认证.授权.加密.会话管理.与Web集成.缓存等. 简单的身份验证 项目目录: 首先,在shiro.ini里配置了用户名和 ...
-
用 Python 和 OpenCV 检测图片上的条形码
用 Python 和 OpenCV 检测图片上的的条形码 这篇博文的目的是应用计算机视觉和图像处理技术,展示一个条形码检测的基本实现.我所实现的算法本质上基于* 上的这个问 ...
-
H.265/HEVC Codec 编解码 (MP4 和 TS)
1. H.265/HEVC 播放器 1) VLC media player 2.1.3 (眼下不支持H.265 TS播放) 2)ffmpeg中的ffplay (如:ffplay hevc.ts) 3 ...
-
asp.net core 多端口监听&;日志服务
1 配置多个端口监听 HostingAbstractionsWebHostBuilderExtensions. public static IWebHostBuilder UseUrls(this I ...
-
(转载)最完整的自动化测试流程:Python编写执行测试用例及定时自动发送最新测试报告邮件
今天笔者就要归纳总结下一整套测试流程,从无到有,实现零突破,包括如何编写测试用例,定时执行测试用例,查找最新生成的测试报告文件,自动发送最新测试报告邮件,一整套完整的测试流程.以后各位只要着重如何编写 ...
-
HDU 5919 Sequence II(主席树+区间不同数个数+区间第k小)
http://acm.split.hdu.edu.cn/showproblem.php?pid=5919 题意:给出一串序列,每次给出区间,求出该区间内不同数的个数k和第一个数出现的位置(将这些位置组 ...
-
Linux网卡性能查看(CentOS)
一.ethtool查看网卡带宽 ethtool eth0 #eth0为网卡名,使用ifconfig查看当前使用的网卡 Speed表示网卡带宽,Duplex表示工作模式,Supported link m ...
-
2--linux命令--查看磁盘空间
du命令用来查看目录或文件所占用磁盘空间的大小.常用选项组合为:du -sh 二.du常用的选项: -h:以人类可读的方式显示 -a:显示目录占用的磁盘空间大小,还要显示其下目录和文件占用磁盘空间的大 ...
-
Alpine里的用户管理命令
注意噢,和普通的linux不一样的. 1, 建立一个指定GID的组: addgroup -g 10001 -S groupA 2, 建立一个指定UID的用户,指定shell, 让它属于指定的用户组. ...