DataSet 的 Merge 方法研究

2016-01-29 12:55 35 1 收藏

DataSet 的 Merge 方法研究,DataSet 的 Merge 方法研究

【 tulaoshi.com - ASP.NET 】

在ADO.NET中我们在合并两个相同或相近的DataSet对象时,通常会使用DataSet的Merge方法,该方法有多个重载版本,在介绍它之前我们先复习Merge方法,以下是MSDN中对Merge方法使用说明:

Merge 方法用于合并架构大致相似的两个 DataSet 对象。合并在客户端应用程序上通常用于将数据源中最近的更改合并到现有的 DataSet 中。这使客户端应用程序能够拥有用数据源中的最新数据刷新的 DataSet。通常在一系列过程的末尾调用 Merge 方法,这些过程涉及验证更改、消除错误、使用更改更新数据源并最后刷新现有的 DataSet。在客户端应用程序中,通常有这样一个按钮,用户可以单击它来收集已更改的数据并对其进行验证,然后将其发送回中间层组件。在这种情况下,将首先调用 GetChanges 方法。该方法返回另一个为验证和合并而优化的 DataSet。第二个 DataSet 对象只包含已更改的 DataTable 和 DataRow 对象,结果产生初始 DataSet 的子集。该子集通常较小,因此可以更有效率地传递回中间层组件。然后,中间层组件将通过存储过程使用更改更新初始数据源。然后,中间层可以发送回一个新的 DataSet,其中包含数据源中的初始数据和最新数据(通过再次运行初始查询);或者它可以发送回包含从数据源对其进行的所有更改的子集。(例如,如果数据源自动创建唯一主键值,则可以将这些值传播回客户端应用程序。)在哪一种情况下都可以使用 Merge 方法将返回的 DataSet 合并回客户端应用程序的初始 DataSet。当将新的源 DataSet 合并到目标中时,DataRowState 值为 Unchanged、Modified 或 Deleted 的任何源行都会与具有同一主键值的目标行相匹配。DataRowState 值为 Added 的源行将匹配主键值与新源行相同的新目标行。根据以上说明,我们知道Merge方法在合并两个数据集时,是以行的主键值为主要对比参照。这样在向数据集添加新行时不会有任何问题,在修改了行且不修改主键值的情况下也不会有问题,但是在更改行时如果你修改了主键的值,那问题就来了…… 下面我们就举例说明:在SQL Server下的一个Products表结构如下:

列名
数据类型
说明
Code
nchar
产品代码(主键列)
Name
nvarchar
产名名称
UnitPrice
numeric
产品单价在.NET中使用XSD生成一个对应的ProductsData.xsd结构如下:
列名
数据类型
说明
Code
string
产品代码(主键列)
Name
string
产名名称
UnitPrice
decimal
产品单价根据MSDN的说明,我们在前台通过ProductsData添加或修改数据后在提交后台更新时,通常做法如下: // 创建一个新数据集来保存对主数据集所做的更改 ProductsData dataSetChanges; dataSetChanges = (ProductsData)(productsData.GetChanges()); // 检查是否做了任何更改 if(dataSetChanges != null) { try { // 需要做一些更改,所以尝试通过调用 update 方法// 和传递数据集以及任何参数来更新数据源 UpdateDataSource(dataSetChanges); productsData.Merge(dataSetChanges); productsData.AcceptChanges(); } catch (System.Exception eUpdate) { throw eUpdate; } }以上代码是根据VS.NET的数据窗体生成向导写的,依据以上代码我们模拟向数据集添加一行数据并更新后的情况:
Code
NameUnitPrice
1001
金砂朱古力120.00 没问题,下面我们修改这行数据再更新,这里我们把Code改为1002,更新之后结果数据并没有按我们预想的把原本行Code列的值1001改为1002,而是添加了一行:
Code
NameUnitPrice
1001
金砂朱古力120.00
1002
金砂朱古力130.00 注:通常情况下我们是很少更改主键值,但在代码没有被使用的情况下,一般是允许更改Code的,特别是在系统实施的阶段。出现以上问题的原因其实不奇怪,按Merge方法的原理,这一点也没错,但这是我们不希望的结果,怎么解决呢,难道不允许用户更改主键,但好象不符合实际。怎么解决呢?既然要用Merge方法,那只有依Merge合并数据的原理去做,不让改主键我们就不改主键,我们可以给前台的ProductsData的数据集加多一个额外的主键ID列,并把它的AutoIncrement设为true,将原本的主键列Code改为Key列,至于后台SQL Server中的源表不作任何修改,修改后如下:
列名
数据类型
说明
ID
Int
自动增长列 (主键)
Code
String
产品代码 (key 键)
Name
String
产名名称
UnitPrice
decimal
产品单价经这样一改,由于ID是自动一个自递增列,我们并不去修改它的值,这样我们就可以随意更改 Code 列的值了,Merge 方法在合并数据时由于是依据ID例进行比对所以也不会再出现前面加多一行的问题了。后记:这是我写的 Blog 申请好之后写的第一篇有关技术的文章,自已感觉写的有点罗嗦,其实写那么长有用的只是最后的几行,这可能对

来源:https://www.tulaoshi.com/n/20160129/1488147.html

延伸阅读
VC启动窗口画面制作方法研究 作者:华南理工大学计算机系 刘正喜 下载本文示例源代码 源代码运行效果图如下: 1. 概述 前几天在设计软件时,选择VC作为开发工具,想做个启动画面,由于以前没有制作过,所以到网上搜了一通。网上有几篇相关文章,有两篇我觉得很...
MERGE无衬线字体设计欣赏 MERGE无衬线字体设计欣赏(2) MERGE无衬线字体设计欣赏(3)
导 读:在ADO中我们最常使用的对象就Recordset了,而在ADO.NET中又增加了一个对象DataSet。本文简要的对比了DateSet和Recordset的异同,这对ADO.NET的初学者非常有帮助! 翻译整理:.net技术网(www.51dotnet.com)郜飞 原文出处:http://www.database-applications.net/articles/dotnet4.html Recordset是一个连接或断开的(通过使用游标)...
简介 WebLogic 是一套基于Java功能强大的电子商务套件,提供了许多功能强大的中间件以方便编程人员编写的jsp、SERVLET 等电子商务应用,可以为企业提供一个完整的商务应用解决方案。对于开发人员 WebLogic 可以在 www.bea.com 免费下载一套完整的 WebLogic,并得到一个限制了 IP 的license,用于学习和开发基于这个套件的代码。而要...
标签: ASP
  ADO+引入了DataSet和DataView的概念。DataSet类似于记录集的集合,因为它能保存一个或多个数据及其之间关系的表(table)。DataView是这些表中之一的实现,类似于ADO 记录集。在上面的例子中,我们的DataSet只保存一个表:Upcoming,我们要将之驻留于ASP+服务器控件中。可以通过以下方式向DataSet中加入更多表。 *重新定义...

经验教程

758

收藏

48
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部