程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> ASP.NET裡的事務處理(ado.net 數據庫應用) 。

ASP.NET裡的事務處理(ado.net 數據庫應用) 。

編輯:.NET實例教程

事務是一組組合成邏輯工作單元的數據庫操作,雖然系統中可能會出錯,但事務將控制和維護每個數據庫的一致性和完整性。如果在事務過程中沒有遇到錯誤,事務中的所有修改都將永久成為數據庫的一部分。如果遇到錯誤,則不會對數據庫作出任何修改。

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

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

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

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

  執行所需的命令。

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

  以下代碼示例使用 microsoft sql Developer Network上的 ADO.Net 實例來演示事務邏輯。


 1SqlConnection myConnection = new SqlConnection("Data Source=localhost;Initi Catalog=Northwind;Integrated Security=SSPI;");
 2
 3myConnection.Open();
 4SqlTransaction myTrans = myConnection.BeginTransaction();// 啟動一個事務
 5
 6SqlCommand myCommand = new SqlCommand();// 為事務創建一個命令
 7myCommand.Connection=myConnection;
 8myCommand.Transaction = myTrans;
 9
10try
11
12{
13
14myCommand.CommandText = "Insert into Region (RegionID, RegionDescription) VALUES (100, "Description")";
15
16myCommand.ExecuteNonQuery();
17
18myCommand.CommandText = "Insert into Region (RegionID, RegionDescription) VALUES (101, "Description")";
19
20myCommand.ExecuteNonQuery();
21
22myTrans.Commit();//提交事務
23
24Response.Write("Both records are written to database.兩次插入數據都成功");

25
26}
27
28catch(Exception e)
29
30{
31
32myTrans.Rollback();//回滾事務
33
34Response.Write(e.ToString());
35
36Response.Write("Neither record was written to database.沒有一次插入數據成功");
37
38}
39
40finally
41
42{
43
44myConnection.Close();
45
46

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved