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 设置为真时发生。

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

DataSet用法1相关推荐

  1. tf.data.Dataset 用法

    tf.data.DatasetAPI支持写入的描述性和高效的输入管线.Dataset用法遵循一个常见模式: 从输入数据创建源数据集. 应用数据集转换来预处理数据. 迭代数据集并处理元素. 迭代以流式方 ...

  2. DataSet用法详细

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

  3. tensorflow 读取图片 Dataset用法

    目录 bmp Dataset.from_tensor_slices: Dataset简单用法 png这个测试ok: 读图片,resize,预测 构建dateset png格式可以训练: bmp Dat ...

  4. 并不简单的翻页时钟(一):样式篇(Flex布局、line-height、data-set用法、css before after伪元素)

    目录 并不简单的翻页时钟 我以为的翻页时钟 实际上的翻页时钟 关键的知识点 效果展示 代码解析 HTML CSS 详解CSS 1.display:flex 元素居中 2.:before .:after ...

  5. torchvision之Dataset用法

    pytorch本身自带的Dataset类提供了一些列数据集,比如常用的EMNIST,CIRFAR10诸如此类.这里简要介绍如何用Dataset导入这些数据集,以及将这些数据集和transforms配合 ...

  6. ASP.NETnbsp;nbsp;DATASET用法

    : c#.net 使用方法 1.创建DataSet对象 DataSet ds = new DataSet(); DataSet ds = new DataSet("DataSetName&q ...

  7. idea怎么给包重命名_IntelliJ IDEA 修改包名

    1.首先将AndroidManifest的Package Name重命名(快捷键shift+F6或者右键Refctor然后Rename)这时Package Name就改变了,但是Src的文件名还没变 ...

  8. 大数据架构师+精英必备技能

    (一)架构师技能树 大数据基础巩固(录播) HDFS分布式文件系统 1.HDFS架构设计 2.HDFS设计思想 3.数据块 4.机架感知 5.容错策略 6.数据本地性策略 7.读写流程分析 8.HDF ...

  9. Dataset的用法简析

    之前的文章,稍微讲了一下Estimator的用法,也提到Estimator的数据处理使用的是tf.data这两个模块是Tensorflow初学者必须掌握的内容.现在,就让我们从大的概念入手,来慢慢理解 ...

最新文章

  1. NSNotificationCenter 线程相关
  2. Navicat连接mysql数据库
  3. 1.2.6 错题整理(组成原理)
  4. 小白的奇幻数学课堂(part3)--你能把一张纸对折7次以上吗
  5. flink 检查点_Flink检查点和恢复
  6. 如何进入embl的ebi网站fasta3服务器,The EMBL-EBI bioinformatics web and programmatic tools framework...
  7. 英特尔发布年度企业社会责任报告,首次定义“全球性挑战”
  8. 谷歌跟风推微信小程序;中兴解禁后首获订单;Yahoo Messenger正式关闭 | 极客头条...
  9. Google卫片下载(转)
  10. word——VBA编程
  11. 视频转换gif动图 - 在线gif制作工具
  12. 会话技术——Cookie
  13. Mathtype 花体字 Euclid math one/two 不能显示的问题
  14. getch计算机错误,为什么getch()在C中抛出一个错误
  15. cb.conjunction()的意思
  16. Midjourney|文心一格prompt教程[Text Prompt(下篇)]:游戏、实物、人物、风景、动漫、邮票、海报等生成,终极模板教学
  17. 可怕的KCFErrordomainCFNetWork 303
  18. 中国服务器连通状态,ppp服务器连通状态显示失败怎么办?
  19. 通讯型高清视频会议摄像机
  20. 计算机视觉专业排名,2020美国人工智能专业排名TOP10!

热门文章

  1. 【计算机组成原理-chapter3】存储系统
  2. 【带你上手云原生体系】第二部分:Go语言从入门到精通
  3. python画笑脸表情_关于Python:Python-用ASCII字符替换unicode表情符号
  4. TK教主:和玄武实验室有关的几个故事 | 人物志
  5. Android APK加固技术初探
  6. 【Java语言】力扣系列----111. 二叉树的最小深度
  7. C语言 判断一个是否素数
  8. python教程实例画图_Python 练习实例57
  9. 数学建模算法与应用学习day1——线性规划问题整数规划问题
  10. 通过建站学运维(课时8)