- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
浅谈DataSet的结构与操作.doc
浅谈DataSet的结构与操作
摘要:DataSet是ADO.NET中的重要组件,它是一个存在于内存中的离线数据库。与关系型数据库类似,DataSet支持多张表,可以建立表之间的关系以及数据之间的约束。该文介绍了DataSet的结构及创建表、添加约束、更新数据的操作。
关键词:DataSet;ADO.NET;数据库
中图分类号:TP311 文献标识码:A 文章编号:1009-3044(2013)34-7675-02
DataSet是ADO.NET的一个重要组成部分,与以往的数据库访问技术不同的是,DataSet是一个不依赖于数据库的独立数据集合。DataSet将从数据库中检索到的数据存放在内存中,即使断开数据链路或关闭数据库,DataSet依然能够被使用,即支持离线访问。
使用DataSet进行编程,程序员不需理会不同数据库之间的差异,因为无论DataSet中的数据来自于哪里,从它获得的编程模型是一样的。而且DataSet的模型与关系数据库基本一致,例如它支持多张表、表与表之间的关系、数据之间的约束等。因此在编程时可以像访问关系型数据库一样访问DataSet。
1 DataSet的结构
在ADO.NET中,DataTable对象就是一张数据表,而DataRelation对象则是表达表之间关系的对象。DataSet可以看作是内存中的离线数据库,它的结构类似于关系型数据库,由DataTableCollection对象和DataRelationCollection对象组成,如图1所示。DataTableCollection对象用作管理组成DataSet的多个DataTable对象,DataRelationCollection对象则对各表之间的关系进行管理。
2 在DataSet中创建表
DataSet中的数据表组成了名为Tables的集合,对数据集中表的各种操作都可以通过该集合对象进行,如添加表、移除表和清除所有表。在DataSet对象中添加数据表的常见方法有直接创建数据表和通过DataAdapter对象填充。
2.1 直接创建数据表
直接向DataSet中添加的数据表,它没有对应的数据源,以这种方式创建的数据表只存在于内存中,对表中数据的修改无法更新到数据库。以下以“客户表”和“订单表”为例,在DataSet中直接添加数据表的代码如下:
上述代码只是向DataSet对象添加了两张空表,表dt1和表dt2并没有内部结构和数据,要添加结构和数据,就得了解DataTable对象的相关操作。如图1所示,DataTable对象主要由Columns、Rows、Constraints三个对象组成,它们分别是列的集合、行的集合、约束的集合。Columns对象用于定义DataTable数据表的架构,它由若干个DataColumn对象组成,负责管理数据表中的列,如增加列或删除列。DataColumn列对象可以定义列名、列的类型,这与在关系型数据库中定义字段相似,代码实现如下:
在建立列对象并添加到DataTable数据表之后,客户表dt1就拥有了字符串类型的名为CustID的列和整型的名为CustName的列,即表dt1拥有了自己的架构。同理订单表dt2也可以创建OrderID、OrderTime和CustID三个列。
在创建表dt1的架构之后,该表依然没有存储任何数据,要向表中添加数据,可以通过DataTable的Rows属性实现。Rows属性是数据表中行的集合,它由若干个数据行组成,负责对DataTable中的行进行管理。DataRow对象就是数据表中的一行,它用来创建数据行并添加数据。给数据表dt1添加两行数据的操作如下:
2.2 通过DataAdapter填充
虽然可以直接在DataSet中创建数据表,但实际应用较少,更常见的是通过DataAdapter对象查询数据库,向DataSet中创建一个同结构的数据表,将结果填充其中。实现如下:
通过上述方法创建并填充数据的DataTable,它的结构与数据源一致。在内存中修改表中的数据后,可以手动更新到数据源。
3 添加表间约束和关系
约束是数据库强制用户执行的规则,以保证数据的完整性。DataSet被认为是“内存中的数据库”,因此它同关系型数据库一样,可以设置主外键关联,建立表之间的关系。 DataSet通过Constraint对象来实现约束,可以建立唯一约束和外键约束。将客户表dt1与订单表dt2中的“CustID”建立外键关联的代码如下:
通过关系可以从父表的一列获取子表对应列中所有的行元素,比如从客户表dt1中的CustID获取订单表dt2中的关于该客户的所有订单信
文档评论(0)