DataSet 的 Merge 方法研究

原创 2004年10月07日 12:23:00

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

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

Merge 方法用于合并架构大致相似的两个 DataSet 对象。合并在客户端应用程序上通常用于将数据源中最近的更改合并到现有的 DataSet 中。这使客户端应用程序能够拥有用数据源中的最新数据刷新的 DataSet。通常在一系列过程的末尾调用 Merge 方法,这些过程涉及验证更改、消除错误、使用更改更新数据源并最后刷新现有的 DataSet

在客户端应用程序中,通常有这样一个按钮,用户可以单击它来收集已更改的数据并对其进行验证,然后将其发送回中间层组件。在这种情况下,将首先调用 GetChanges 方法。该方法返回另一个为验证和合并而优化的 DataSet。第二个 DataSet 对象只包含已更改的 DataTable DataRow 对象,结果产生初始 DataSet 的子集。该子集通常较小,因此可以更有效率地传递回中间层组件。然后,中间层组件将通过存储过程使用更改更新初始数据源。然后,中间层可以发送回一个新的 DataSet,其中包含数据源中的初始数据和最新数据(通过再次运行初始查询);或者它可以发送回包含从数据源对其进行的所有更改的子集。(例如,如果数据源自动创建唯一主键值,则可以将这些值传播回客户端应用程序。)在哪一种情况下都可以使用 Merge 方法将返回的 DataSet 合并回客户端应用程序的初始 DataSet

当将新的源 DataSet 合并到目标中时,DataRowState 值为 UnchangedModified 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

Name

UnitPrice

1001

金砂朱古力

120.00

没问题,下面我们修改这行数据再更新,这里我们把Code改为1002,更新之后结果数据并没有按我们预想的把原本行Code列的值1001改为1002,而是添加了一行:

Code

Name

UnitPrice

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 申请好之后写的第一篇有关技术的文章,自已感觉写的有点罗嗦,其实写那么长有用的只是最后的几行,这可能对那些.NET高手们只是雕虫小技,所以让高手们见笑了。

DataSet 的 Merge()

在ADO.NET中我们在合并两个相同或相近的DataSet对象时,通常会使用DataSet的Merge方法,该方法有多个重载版本,在介绍它之前我们先复习Merge方法,以下是MSDN中对Merge方法...
  • ljsql
  • ljsql
  • 2007年08月11日 15:03
  • 4207

DataSet.Merge与DataTable操作小技巧

对DataTable的一些操作,如:想从一个DataTable中抽中一部份DataRow生成另一个DataTable,或是调整DataTable内的Sort(排序)方式等,着实让我头痛一阵子。今天在无...
  • ggj00006
  • ggj00006
  • 2009年03月11日 15:22
  • 627

DataSet 的 Merge 方法

在ADO.NET中我们在合并两个相同或相近的DataSet对象时,通常会使用DataSet的Merge方法,该方法有多个重载版本,在介绍它之前我们先复习Merge方法,以下是MSDN中对Merge方法...
  • ranlianjie
  • ranlianjie
  • 2007年06月14日 09:45
  • 1148

DataSet..::.Merge 方法 (DataSet)

将指定的 DataSet 及其架构合并到当前 DataSet 中。 命名空间:   System....
  • lai123wei
  • lai123wei
  • 2009年09月07日 14:29
  • 1258

【C#】合并DataSet

当你用到合并DataSet的时候,说明你的sql是多少有点问题的,大多数情况下,是可以通过sql,直接拉取所有的数据的,当然也可能是业务上的需求。当返回的两个Dataset的结构相同时,可以使用Mer...
  • f627422467
  • f627422467
  • 2016年09月02日 08:56
  • 836

做课题与科研项目常用的研究方法

研究方法不出“硬伤” 1、常用的研究方法有文献研究法、教育观察法、经验总结法、个案研究法、行动研究法、实验研究法、历史研究法、调查研究法、比较研究法、叙事研究法等。 2、研究类型或途径、或...
  • neilol
  • neilol
  • 2015年06月18日 15:28
  • 3231

hibernate.merge()方法

转载地址:http://littie1987.iteye.com/blog/1039082   下面来讲讲Hibernate的merge方法。我打算按照hibernate对象生命周期的三个状态来讲...
  • xq30397022
  • xq30397022
  • 2013年10月15日 17:57
  • 1560

科研课题研究方法

   1.科研课题研究方法1 n定性分析与定量分析 n定性分析:说明事物的性质及其内在规定性与规律性 n定量分析:分析事物现象之间量的关系。 n规范研究与实证研究 n规范研究:以一定的价值判断为基础,...
  • m57091003
  • m57091003
  • 2007年11月06日 19:19
  • 10018

Hibernate中的merge方法详解

如果merge的对象在数据库中不存在,merge将会进行save操作,作用等同于updateOrSave();而update因为找不多对象而报错。 如果merge的对象能在数据库中操作,merge操作...
  • csujiangyu
  • csujiangyu
  • 2015年09月05日 11:03
  • 508

hibernate saveOrUpdate方法和merge的区别

首先 saveOrUpdate返回void 也就是什么都不返回 而merge会返回一个对象 其次 saveOrUpdate的做法是:自动判断该对象是否曾经持久化过,如果曾持久化过则使用updat...
  • w938706428
  • w938706428
  • 2014年11月06日 10:43
  • 3564
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:DataSet 的 Merge 方法研究
举报原因:
原因补充:

(最多只允许输入30个字)