VB.NET 中启动ADO.NET事务,实现对数据库操作的整体性。

翻译 2006年05月21日 08:50:00

示例
[Visual Basic, C#] 下面的示例创建一个 SqlConnection 和一个 SqlTransaction。它还演示如何使用 BeginTransaction、Commit 和 Rollback 方法。
[Visual Basic, C#] 注意   此示例显示如何使用 BeginTransaction 的一个重载版本。有关其他可用示例,请参阅单独的重载主题。
[Visual Basic]
Public Sub RunSqlTransaction(myConnString As String)
    Dim myConnection As New SqlConnection(myConnString)
    myConnection.Open()
   
    Dim myCommand As SqlCommand = myConnection.CreateCommand()
    Dim myTrans As SqlTransaction
   
    ' Start a local transaction
    myTrans = myConnection.BeginTransaction(IsolationLevel.ReadCommitted, "SampleTransaction")
    ' Must assign both transaction object and connection
    ' to Command object for a pending local transaction
    myCommand.Connection = myConnection
    myCommand.Transaction = myTrans

    Try
      myCommand.CommandText = "Insert into Region (RegionID, RegionDescription) VALUES (100, 'Description')"
      myCommand.ExecuteNonQuery()
      myCommand.CommandText = "Insert into Region (RegionID, RegionDescription) VALUES (101, 'Description')"
      myCommand.ExecuteNonQuery()
      myTrans.Commit()
      Console.WriteLine("Both records are written to database.")
    Catch e As Exception
      Try
        myTrans.Rollback("SampleTransaction")
      Catch ex As SqlException
        If Not myTrans.Connection Is Nothing Then
          Console.WriteLine("An exception of type " & ex.GetType().ToString() & _
                            " was encountered while attempting to roll back the transaction.")
        End If
      End Try
   
      Console.WriteLine("An exception of type " & e.GetType().ToString() & _
                      "was encountered while inserting the data.")
      Console.WriteLine("Neither record was written to database.")
    Finally
      myConnection.Close()
    End Try
End Sub 'RunSqlTransaction
[C#]
public void RunSqlTransaction(string myConnString)
 {
    SqlConnection myConnection = new SqlConnection(myConnString);
    myConnection.Open();

    SqlCommand myCommand = myConnection.CreateCommand();
    SqlTransaction myTrans;

    // Start a local transaction
    myTrans = myConnection.BeginTransaction(IsolationLevel.ReadCommitted,"SampleTransaction");
    // Must assign both transaction object and connection
    // to Command object for a pending local transaction
    myCommand.Connection = myConnection;
    myCommand.Transaction = myTrans;

    try
    {
      myCommand.CommandText = "Insert into Region (RegionID, RegionDescription) VALUES (100, 'Description')";
      myCommand.ExecuteNonQuery();
      myCommand.CommandText = "Insert into Region (RegionID, RegionDescription) VALUES (101, 'Description')";
      myCommand.ExecuteNonQuery();
      myTrans.Commit();
      Console.WriteLine("Both records are written to database.");
    }
    catch(Exception e)
    {
      try
      {
        myTrans.Rollback("SampleTransaction");
      }
      catch (SqlException ex)
      {
        if (myTrans.Connection != null)
        {
          Console.WriteLine("An exception of type " + ex.GetType() +
                            " was encountered while attempting to roll back the transaction.");
        }
      }
   
      Console.WriteLine("An exception of type " + e.GetType() +
                        " was encountered while inserting the data.");
      Console.WriteLine("Neither record was written to database.");
    }
    finally
    {
      myConnection.Close();
    }
}

相关文章推荐

c#数据库操作DataGridView控件的使用,ADO.NET

适合初学者,0基础; 题目: 利用DataGridView控件和ADO.NET完成数据的显示,删除,修改等; 最终运行的效果如图所示: 步骤: 1.首先同样步骤:打开vs2010,Fil...

我封装的ADO.NET对数据库操作经典类

using System;using System.Collections;using System.Collections.Specialized;using System.Runtime.Remo...

关于ADO.NET数据库操作中的增删改查讲解

我们要连接数据库之后就要对它进行增删改查,这里我们就详细的分析一下吧。对于ADO.NET数据库操作Insert,Update,Delete等单向操作,对于插入、删除、修改等操作,由于是客户端应用程序向...
  • letIgo
  • letIgo
  • 2011年10月17日 15:59
  • 1067

C# ADO.NET_数据库操作的封装

1.App.config                             providerName="System.Data.SqlClient" />   ...

【ADO.NET】数据库操作

接触ADO.NET,下午自己摸索着用代码实现了点增删改查的知识,特此总结  分享一下   Select  :用于检索数据 Insert :用于增加数据到数据库 Update:用于从数据库中修改现存...

ADO.NET数据库操作

  • 2008年09月23日 15:36
  • 82KB
  • 下载

ADO.NET通用数据库操作类

最近经常看到一些人在秀其多年来积累经验而成的数据库操作类,在此我也秀一把。 本人对ORM相关的东西是极不喜欢的,可能与平常接触到的项目所操作的数据量都较大、业务较复杂吧。另对那种通过自己编写实体类,...

ADO.NET数据库操作

  • 2013年01月07日 15:18
  • 1.63MB
  • 下载

封装的ADO.NET对数据库操作经典类 代码

using System;using System.Collections;using System.Collections.Specialized;using System.Runtime.Remo...
  • zz_mm
  • zz_mm
  • 2011年07月11日 10:52
  • 581
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:VB.NET 中启动ADO.NET事务,实现对数据库操作的整体性。
举报原因:
原因补充:

(最多只允许输入30个字)