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

开发 后端
文章介绍了使用ADO.NET RowUpdated执行操作的范围和RowUpdated对事件的处理,希望对大家有技术上的帮助。

ADO.NET RowUpdated还是比较常用的,于是我研究了一下,在这里拿出来和大家分享一下,希望对大家有用。在数据源中处理对 DataSet 中某行的任何更新之前,将引发了RowUpdated。在数据源中处理对 DataSet 中某行的任何更新之后,将引发 RowUpdated。

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

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

#T#可以使用 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 的行为)。

  1. ' Assumes that connection is a valid SqlConnection object.  
  2. Dim custAdapter As SqlDataAdapter = New SqlDataAdapter( _  
  3. "SELECT CustomerID, CompanyName FROM Customers", connection)  
  4.  
  5. ' Add handlers.  
  6. AddHandler custAdapter.RowUpdating, New SqlRowUpdatingEventHandler( _  
  7. AddressOf OnRowUpdating)  
  8. AddHandler custAdapter.RowUpdated, New SqlRowUpdatedEventHandler(  
  9. AddressOf OnRowUpdated)  
  10.  
  11. ' Set DataAdapter command properties, fill DataSet, and modify DataSet.  
  12.  
  13. custAdapter.Update(custDS, "Customers")  
  14.  
  15. ' Remove handlers.  
  16. RemoveHandler custAdapter.RowUpdating, _  
  17. New SqlRowUpdatingEventHandler(AddressOf OnRowUpdating)  
  18. RemoveHandler custAdapter.RowUpdated, _  
  19. New SqlRowUpdatedEventHandler(AddressOf OnRowUpdated)  
  20.  
  21. Private Shared Sub OnRowUpdating(sender As Object, _  
  22. args As SqlRowUpdatingEventArgs)  
  23. If args.StatementType = StatementType.Delete Then  
  24. Dim tw As System.IO.TextWriter = _ 
  25. System.IO.File.AppendText("Deletes.log")  
  26. tw.WriteLine( _  
  27. "{0}: Customer {1} Deleted.", DateTime.Now, args.Row(_  
  28. "CustomerID", DataRowVersion.Original))  
  29. tw.Close()  
  30. End If  
  31. End Sub  
  32.  
  33. Private Shared Sub OnRowUpdated( _  
  34. sender As Object, args As SqlRowUpdatedEventArgs)  
  35. If args.Status = UpdateStatus.ErrorsOccurred  
  36. args.Status = UpdateStatus.SkipCurrentRow  
  37. argsargs.Row.RowError = args.Errors.Message  
  38. End If  
  39. End Sub 
责任编辑:田树 来源: 博客
相关推荐

2009-12-29 15:38:05

ADO.NET语句

2009-11-11 17:12:25

ADO.NET批处理

2009-11-12 11:38:03

ADO.NET连接事件

2009-12-30 15:17:06

ADO.NET选项

2009-12-31 16:09:22

ADO与ADO.NET

2009-12-23 11:25:30

ADO.NET处理

2009-12-30 16:05:20

ADO.NET实例

2009-11-13 14:29:13

ADO.NET Mer

2009-12-22 14:15:08

ADO.Net处理数据

2009-11-12 12:39:16

ADO.NET Sta

2009-12-29 16:12:25

ADO程序员

2009-12-21 16:45:41

ADO.NET程序

2009-11-12 14:03:03

ADO.NET数据集约

2009-11-13 09:45:54

ADO.NET程序集

2009-10-29 11:18:47

ADO.NET SQL

2010-01-04 13:16:31

ADO.NET命令

2009-11-03 15:47:10

ADO.NET数据异步

2009-12-21 16:02:48

ADO.NET命令

2009-12-28 15:11:36

ADO.NET专家

2009-12-29 14:41:13

ADO.NET 数据集
点赞
收藏

51CTO技术栈公众号