数据库研究期刊论文范文
所属栏目:计算机信息管理论文
发布时间:2014-01-09 16:28:03 更新时间:2014-01-09 16:46:02
DataSet是ADO.NET的一个重要组成部分,与以往的数据库访问技术不同的是,DataSet是一个不依赖于数据库的独立数据集合。DataSet将从数据库中检索到的数据存放在内存中,即使断开数据链路或关闭数据库,DataSet依然能够被使用,即支持离线访问。
摘要:DataSet是ADO.NET中的重要组件,它是一个存在于内存中的离线数据库。与关系型数据库类似,DataSet支持多张表,可以建立表之间的关系以及数据之间的约束。该文介绍了DataSet的结构及创建表、添加约束、更新数据的操作。
关键词:DataSet,ADO.NET,数据库
使用DataSet进行编程,程序员不需理会不同数据库之间的差异,因为无论DataSet中的数据来自于哪里,从它获得的编程模型是一样的。而且DataSet的模型与关系数据库基本一致,例如它支持多张表、表与表之间的关系、数据之间的约束等。因此在编程时可以像访问关系型数据库一样访问DataSet。
1DataSet的结构
在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中的关于该客户的所有订单信息。
4将数据更新到数据库
由于DataSet对象存储于内存中,对该对象中数据的更改并不会反映到数据源中,如果要将DataSet中修改后的数据更新到数据源,需借助DataAdapter对象和CommandBuilder对象。
DataAdapter不会自动生成实现DataSet的更改与关联的SQLServer实例之间协调所需的Transact-SQL语句。但是,如果设置了DataAdapter的SelectCommand属性,则可以创建一个CommandBuilder对象来自动生成用于单表更新的Transact-SQL语句。然后,CommandBuilder将生成其他任何未设置的Transact-SQL语句,即对应的insert、update、delete语句。下面是将DataSet中数据更新到数据库的代码:
5小结
DataSet是一个复杂而又强大的ADO.NET组件,该文对DataSet的结构和组成作了简要的介绍,通过实例分析,对DataSet的常用操作进行了演示,为学习和研究数据库编程提供了很好的参考。
参考文献:
[1]陈明忠,江永池.ASP.NET网站开发案例教程[M].北京:清华大学出版社,2011:119-125.
[2]陈义辉,沙继东.企业级网站开发项目教程(ASP.NET)[M].北京:中国人民大学出版社,2010:102-112.
[3]陈燕群,张华贵,王海燕.ADO.NET数据库编程浅析[J].电脑知识与技术,2012(6):1316-1318.
[4]高鹏,宋丽芳.NET数据库操作浅析[J].北京农业职业学院学报,2011,25(3):21-24.
[5]杨昭兵.基于ASP.NET数据库的操作[J].科技广场,2011(9):94-96.
月期刊平台服务过的文章录用时间为1-3个月,依据20年经验,经月期刊专家预审通过后的文章,投稿通过率100%以上!