导航教你ADO.NET MergeFailed事件运用

开发 后端
文章这里深入细致的介绍了关于ADO.NET MergeFailed事件的概述和初始化ADO.NET MergeFailed事件,希望对大家有帮助。

我们大家都知道DataSet对象提供三个事件:Disposed、Initialized 和 MergeFailed。这里我们只对ADO.NET MergeFailed事件做出详细的介绍。

ADO.NET MergeFailed事件

#T#DataSet 对象的最常用事件是 MergeFailed,当要合并的 DataSet 对象的架构发生冲突时,会引发该事件。当目标和源 DataRow 有相同的主键值,且 EnforceConstraints 属性设置为 true 时会发生这种情况。例如,如果所合并表的主键列与两个 DataSet 对象中的表的相同,则将发生异常并引发 MergeFailed 事件。传递给 MergeFailed 事件的 MergeFailedEventArgs 对象具有 Conflict 属性(标识两个 DataSet 对象之间的架构冲突)和 Table 属性(标识发生冲突的表的名称)。

下面的代码段演示如何为 ADO.NET MergeFailed事件添加事件处理程序。

  1. AddHandler workDS.MergeFailed, New MergeFailedEventHandler( _  
  2. AddressOf DataSetMergeFailed)  
  3.  
  4. Private Shared Sub DataSetMergeFailed(_  
  5. sender As Object,args As MergeFailedEventArgs)  
  6. Console.WriteLine("Merge failed for table " & args.Table.TableName)  
  7. Console.WriteLine("Conflict = " & args.Conflict)  
  8. End Sub  

初始化ADO.NET MergeFailed事件

在 DataSet 构造函数初始化 DataSet 的新实例后会发生 Initialized 事件。

如果 DataSet 已完成初始化,IsInitialized 属性会返回 true;否则,返回 false。BeginInit 方法,它开始初始化 DataSet,将 IsInitialized 设置为 false。EndInit 方法(用于结束 DataSet 的初始化)将它设置为 true。Visual Studio 设计环境使用这些方法初始化其他组件使用的 DataSet。通常不会在代码中使用这些方法。

 释放事件

DataSet 派生自 MarshalByValueComponent 类,该类可公开 Dispose 方法和 Disposed 事件。Disposed 事件添加了一个事件处理程序以侦听组件上已释放的事件。如果您要在调用 Dispose 方法时执行代码,则可以使用 DataSet 的 Disposed 事件。Dispose 释放由 MarshalByValueComponent 使用的资源。

DataSet 和 DataTable 对象继承 MarshalByValueComponent 并支持用于远程处理的 ISerializable 接口。这两个对象是***可远程处理的 ADO.NET 对象。有关更多信息,请参见.NET 远程处理。有关使用 DataSet 时的其他可用事件的信息,请参见处理 DataTable 事件 (ADO.NET)和处理 DataAdapter 事件 (ADO.NET)。

责任编辑:田树 来源: 博客
相关推荐

2009-12-23 11:25:30

ADO.NET处理

2009-11-13 09:30:28

2009-11-12 11:38:03

ADO.NET连接事件

2009-11-11 10:39:19

ADO.NET Fin

2009-11-03 14:46:47

ADO.NET数据库

2009-11-12 12:39:16

ADO.NET Sta

2009-11-11 10:35:24

ADO.NET运用

2009-12-28 15:11:36

ADO.NET专家

2009-11-03 16:37:10

2009-09-14 13:37:25

LINQ ADO.NE

2009-11-13 11:18:22

ADO.NET修改数据

2009-11-03 14:22:10

ADO.NET Exc

2009-11-11 14:04:14

ADO.NET连接池

2009-11-13 11:08:04

ADO.NET Row

2010-01-04 10:48:30

ADO.NET特色

2011-05-20 11:31:07

ADO.NET

2009-11-13 14:19:06

ADO.NET事务

2011-06-02 09:39:29

ADO.NET

2009-11-04 12:45:33

ADO.NET Dat

2009-11-12 13:53:27

ADO.NET Sel
点赞
收藏

51CTO技术栈公众号