• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
  • ASP.NET里的事務處理

    發表于:2007-05-25來源:作者:點擊數: 標簽:事務處理一組合成ASP.NET事務
    事務是一組組合成邏輯工作單元的 數據庫 操作,雖然系統中可能會出錯,但事務將控制和維護每個數據庫的一致性和完整性。如果在事務過程中沒有遇到錯誤,事務中的所有修改都將永久成為數據庫的一部分。如果遇到錯誤,則不會對數據庫作出任何修改。 例如,在一
      事務是一組組合成邏輯工作單元的數據庫操作,雖然系統中可能會出錯,但事務將控制和維護每個數據庫的一致性和完整性。如果在事務過程中沒有遇到錯誤,事務中的所有修改都將永久成為數據庫的一部分。如果遇到錯誤,則不會對數據庫作出任何修改。

      例如,在一個銀行應用程序中,如果資金從一個帳戶轉到另一個帳戶,則會將一定的金額記入一個帳戶的貸方,同時將相同的金額記入另一個帳戶的借方。由于計算機可能會因為停電、網絡中斷等原因而出現故障,所以有可能更新了一個表中的行,但沒有更新相關表中的行。如果數據庫支持事務,則可以將數據庫操作組成一個事務,以防止因這些事件而使數據庫出現不一致。

      在 ADO.NET 中,可以使用 Connection 和 Transaction 對象來控制事務。若要執行事務,請執行下列操作:

      調用 Connection 對象的 BeginTransaction 方法來標記事務的開始。BeginTransaction 返回對 Transaction 的引用。請保留此引用,以便將其分配給在事務中登記的 Command。

      將 Transaction 對象分配給要執行的 Command 的 Transaction 屬性。如果通過活動的 Transaction 對象對 Connection 執行 Command,但該 Transaction 對象尚未分配給 Command 的 Transaction 屬性,則將引發異常。

      執行所需的命令。

      調用 Transaction 對象的 Commit 方法來完成事務,或調用 Rollback 方法來取消事務。

      以下代碼示例使用 Microsoft? SQL Server? 上的 ADO.NET 來演示事務邏輯。

    SqlConnection myConnection = new SqlConnection("Data Source=localhost;Initial Catalog=Northwind;Integrated Security=SSPI;");
    myConnection.Open();
    // 啟動一個事務
    SqlTransaction myTrans = myConnection.BeginTransaction();

    // 為事務創建一個命令
    SqlCommand myCommand = new SqlCommand();
    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)
    {
    myTrans.Rollback();
    Console.WriteLine(e.ToString());
    Console.WriteLine("Neither record was written to database.");
    }
    finally
    {
    myConnection.Close();
    }

    原文轉自:http://www.kjueaiud.com

    評論列表(網友評論僅供網友表達個人看法,并不表明本站同意其觀點或證實其描述)
    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>