怎么用ADO.NET RowUpdated添加删除事件处理程序

发布时间:2021-12-03 16:59:58 作者:iii
来源:亿速云 阅读:115

这篇文章主要讲解了“怎么用ADO.NET RowUpdated添加删除事件处理程序”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用ADO.NET RowUpdated添加删除事件处理程序”吧!

在数据源中处理对 DataSet 中某行的任何更新之前,将引发了RowUpdated。在数据源中处理对 DataSet 中某行的任何更新之后,将引发 RowUpdated。

因此,可以使用 RowUpdating 执行下列操作:在更新行为发生之前对其进行修改,在更新将发生时提供附加处理,保留对已更新行的引用,取消当前更新并将其安排在以后进行批处理,等等。RowUpdated 对于响应更新期间发生的错误和异常是非常有用的。 您可以向 DataSet 以及重试逻辑等添加错误信息。

传递给 RowUpdating 和 RowUpdated 事件的 RowUpdatingEventArgs 和 RowUpdatedEventArgs 参数包括: Command 属性,它引用用来执行更新的 Command 对象;Row 属性,它引用包含更新信息的 DataRow 对象;StatementType 属性,它指示所执行的更新类型;TableMapping(如果适用);以及操作的 Status。

可以使用 Status 属性来确定在执行该操作期间是否发生了错误;如果需要,还可以使用该属性来控制对当前行和结果行所执行的操作。 当该事件发生时,Status 属性将为 Continue 或 ErrorsOccurred。 下表演示为了控制更新过程中的后继操作,可以将 Status 属性设置为的值。如果将 Status 属性设置为 ErrorsOccurred,则会引发异常。 您可以通过将 Errors 属性设置为所需异常来控制所引发的异常。 如果使用 Status 的其他值之一,则可防止引发异常。

也可以使用 ContinueUpdateOnError 属性为更新的行处理错误。 如果 DataAdapter.ContinueUpdateOnError 为 true,那么当行的更新导致引发异常时,该异常的文本被放入特定行的 RowError 信息中,并且处理将会继续而不会引发异常。 这使您能够在 Update 完成时对错误作出响应;与此相反的是ADO.NET RowUpdated事件,它使您能够在遇到错误时响应错误。

以下代码示例显示如何添加和移除事件处理程序。 RowUpdating 事件处理程序编写带有时间戳的所有已删除记录的日志。ADO.NET RowUpdated事件处理程序将错误信息添加到 DataSet 中行的 RowError 属性、取消显示异常,并继续处理(镜像 ContinueUpdateOnError = true 的行为)。

' Assumes that connection is a valid SqlConnection object.  Dim custAdapter As SqlDataAdapter = New SqlDataAdapter( _  "SELECT CustomerID, CompanyName FROM Customers", connection)   ' Add handlers.  AddHandler custAdapter.RowUpdating, New SqlRowUpdatingEventHandler( _  AddressOf OnRowUpdating)  AddHandler custAdapter.RowUpdated, New SqlRowUpdatedEventHandler(  AddressOf OnRowUpdated)   ' Set DataAdapter command properties, fill DataSet, and modify DataSet.   custAdapter.Update(custDS, "Customers")   ' Remove handlers.  RemoveHandler custAdapter.RowUpdating, _  New SqlRowUpdatingEventHandler(AddressOf OnRowUpdating)  RemoveHandler custAdapter.RowUpdated, _  New SqlRowUpdatedEventHandler(AddressOf OnRowUpdated)   Private Shared Sub OnRowUpdating(sender As Object, _  args As SqlRowUpdatingEventArgs)  If args.StatementType = StatementType.Delete Then  Dim tw As System.IO.TextWriter = _ System.IO.File.AppendText("Deletes.log")  tw.WriteLine( _  "{0}: Customer {1} Deleted.", DateTime.Now, args.Row(_  "CustomerID", DataRowVersion.Original))  tw.Close()  End If  End Sub   Private Shared Sub OnRowUpdated( _  sender As Object, args As SqlRowUpdatedEventArgs)  If args.Status = UpdateStatus.ErrorsOccurred  args.Status = UpdateStatus.SkipCurrentRow  argsargs.Row.RowError = args.Errors.Message  End If  End Sub

感谢各位的阅读,以上就是“怎么用ADO.NET RowUpdated添加删除事件处理程序”的内容了,经过本文的学习后,相信大家对怎么用ADO.NET RowUpdated添加删除事件处理程序这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

推荐阅读:
  1. java中的事件是什么?怎么用
  2. VB.NET控件数组怎么用

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

ado.net

上一篇:怎么解析KVM虚拟化原理中的CPU虚拟化

下一篇:如何解析KVM虚拟化原理中的内存虚拟化

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》