人人做人人澡人人爽欧美,国产主播一区二区,久久久精品五月天,羞羞视频在线观看免费

當前位置:蘿卜系統下載站 > 技術開發教程 > 詳細頁面

ASP.NET里的事務處理

ASP.NET里的事務處理

更新時間:2022-07-26 文章作者:未知 信息來源:網絡 閱讀次數:


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



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



在 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();
}

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

網站地圖xml | 網站地圖html
主站蜘蛛池模板: 富宁县| 乡宁县| 平邑县| 苏尼特右旗| 长顺县| 井研县| 务川| 称多县| 苍山县| 武安市| 邵东县| 东乡县| 含山县| 弥勒县| 古田县| 阿尔山市| 元阳县| 阜城县| 南雄市| 托克逊县| 太谷县| 东宁县| 茌平县| 鹰潭市| 榕江县| 那曲县| 绥德县| 浏阳市| 紫云| 施甸县| 电白县| 绥滨县| 巴彦淖尔市| 钟祥市| 固安县| 澎湖县| 中卫市| 若尔盖县| 兴山县| 长岛县| 无极县|