国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

ASP.NET里的事務處理

2024-07-10 12:58:02
字體:
來源:轉載
供稿:網友
  事務是一組組合成邏輯工作單元的數據庫操作,雖然系統中可能會出錯,但事務將控制和維護每個數據庫的一致性和完整性。如果在事務過程中沒有遇到錯誤,事務中的所有修改都將永久成為數據庫的一部分。如果遇到錯誤,則不會對數據庫作出任何修改。

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


  在 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();
}
國內最大的酷站演示中心!
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 巴彦淖尔市| 师宗县| 定结县| 磐安县| 琼结县| 灵川县| 武功县| 北宁市| 安阳市| 凤城市| 寿宁县| 湘阴县| 攀枝花市| 无锡市| 高邮市| 新沂市| 正镶白旗| 阿鲁科尔沁旗| 平舆县| 隆昌县| 新建县| 天气| 湾仔区| 方城县| 塘沽区| 南昌县| 施甸县| 大理市| 宜良县| 望都县| 射阳县| 博客| 贵阳市| 商洛市| 伊宁县| 黑水县| 台州市| 准格尔旗| 昌乐县| 揭西县| 明星|