导航教你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)。

新闻名称:导航教你ADO.NET MergeFailed事件运用
分享地址:http://www.shufengxianlan.com/qtweb/news4/9704.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联