DataSet 的 Merge 方法研究

在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
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高手们只是雕虫小技,所以让高手们见笑了。

时间: 2024-09-14 16:19:24

DataSet 的 Merge 方法研究的相关文章

基于多相检测方法研究酿造微生物群落关键技术的开发与应用

从四川省科技厅获悉,四川省郫县http://www.aliyun.com/zixun/aggregation/537.html" style="line-height: 1.6;">豆瓣股份有限公司与四川大学等多家单位共同完成的"基于多相检测方法研究酿造微生物群落关键技术的开发与应用"项目,获得了"2011年四川省科技进步一等奖".此项成果的取得为公司在2012年实现销售收入3亿元的奋斗目标和今后冲刺资本市场增加了新的筹码. 据从

面向可追溯的物联网数据采集与建模方法研究

面向可追溯的物联网数据采集与建模方法研究 中国农业大学  齐林 研究的主要贡献与创新之处是:(1)提出了基于WSN的可追溯感知数据采集方法和基于SPC的时域压缩方法,提高了感知数据采集效率,并延长了监测网络寿命.基于WSN所研发的可追溯感知数据采集方法软.硬件原型,测试结果表明通信链路可靠,感知节点对生鲜农产品供应链保鲜工艺环境的兼容性.传感器硬件兼容性好:基于SPC所设计的改进X-Rs感知数据时域压缩算法与阈值.K-滑动均值算法对比,能耗在同一数量级,平稳时间序列的Se为最优,2种时间序列平稳

云计算中加密数据的模糊关键字搜索方法研究

云计算中加密数据的模糊关键字搜索方法研究 陕西师范大学 杜军强 本论文从以下几个方面展开研究: 首先介绍了公钥加密关键字搜索的基本概念,从公钥加密搜索的定义出发介绍公钥加密关键字搜索的模型,从中引入公钥加密关键字搜索蕴含基于身份的加密.随后给出可搜索加密方案的构造,从双线性映射的概念.可证明安全性的概念.随机预言机模型与公钥加密的安全性来引入公钥加密关键字搜索具体方案的构造,最后对该方案的安全性做了分析证明. 其次提出支持多种字符串类似性操作的R+树来构建索引,实现云计算中对加密数据的模糊关键字

基于云计算的冷链物流配送车辆路径优化方法研究

基于云计算的冷链物流配送车辆路径优化方法研究 徐优香  王译 针对冷链物流配送车辆路径优化问题,分析云计算模式下处理配送车辆实时路径 的优势,建立了冷链物流配送车辆路径优化应用服务架构:并在该架构下获取多源实时交通信息,分析车辆配送时间和综合成本,构建了冷链物流配送车辆路径优化 模型,并在云计算环境下利用粗粒度并行遗传算法对模型进行求解,实验结果表明云计算环境下冷藏车辆实时路径优化方法是有效的,该方法对冷链物流配送成本实 现精细化控制,提高配送服务效率,具有实际意义. 基于云计算的冷链物流配送车

车联网环境下交通信息传输保障方法研究

车联网环境下交通信息传输保障方法研究 吉林大学 闫超 本文紧紧围绕车联网环境下交通信息海量.时变.多源的特点,设计了车联网的系统结构:分析了车载移动自组织网络的信息节点拓扑结构变化规律,通过研究车载自组织网络,提出基于交通信息传输环境维护方法和车间交通信息传输方法的车联网环境下交通信息传输保障方法,并分析了相关方法的性能,改进了传统移动自组织网络相关信息传输协议的缺陷,使得交通信息传输的稳定性和效率大大提高,同时控制了网络通信开销和能耗. 车联网环境下交通信息传输保障方法研究

虚拟机环境检测方法研究综述

虚拟机环境检测方法研究综述 杨峰 姜辉 诸葛建伟 段海新 虚拟化技术带来的资源利用.管理和隔离的优势,使其被广泛应用在虚拟服务器.恶意代码分析.云计算平台搭建等领域.恶意代码的编写者和安全研究人员也在虚拟化发展热潮中展开了新一轮的技术博弈,如何检测虚拟环境的存在成为当前研究的热点.介绍虚拟机环境检测方法的意义,从本地虚拟机环境检测和远程虚拟机环境检测两个方面分别展开举例说明检测的原理和方法,在总结虚拟机环境检测方法的基础上,指出虚拟化透明性增强的方向,探讨和分析未来的发展趋势. 虚拟机环境检测方

基于MapReduce模型的生物量遥感并行反演方法研究

基于MapReduce模型的生物量遥感并行反演方法研究 付天新,刘正军,闫浩文 MapReduce 模型是一种基于云计算平台下新型的并行编程模型.文中MapReduce 并行编程模型应用到遥感影像并行化处理中,以2005-2009 年5a生长季期( 5-10 月) MODIS13Q1 数据产品为数据源,对青海省三江源地区的生物量( 草地总生物量和可食草量) 进行并行化反演,研究基于该模型的生物量遥感并行反演方法.实验分析结果表明: 基于该模型的并行生物量遥感反演结果与经过精度验证的串行反演结果一

智慧社区配电变压器在线监控与故障诊断方法研究与应用

智慧社区配电变压器在线监控与故障诊断方法研究与应用 东北大学  娄雪宁 论文主要工作如下: (1)从目前社区内配电设备存在的实际问题出发,综述了现有的变压器故障诊断方法. (2)根据设备运行状态与故障现象之间存在的复杂非线性关系,BP神经网络有很好的复杂非线性映射功能,因此采用BP神经网络对配电变压器进行故障诊断. (3)针对变压器故障诊断的需求,设计了BP网络结构.为了解决BP神经网络收敛速度慢.较易陷入局部极小值的问题,将遗传算法与神经网络结合,组成遗传-BP网络混合算法.该算法利用遗传算法

.net中DataTable DataSet DataView使用方法

本篇文章主要介绍DataTable,DataSet的使用方法,属性总结型,因此只抛出重点.关于DataTable,DataSet这里简要说明下:dataset是数据集,可以包含datatable,以及各个数据表之间的关系等,datatable是数据表,有列columns,行rows等.DataView是视图,用来创建DataTable中所存储数据的不同视图,通常用于数据绑定,方法如下:  代码如下 复制代码  DataView DV = ds.Tables["表名"].DefaultV