- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一、事务的介绍.NET Framework 开发员指南事务是一组组合成逻辑工作单元的操作,虽然系统中可能会出错,但事务将控制和维护事务中每个操作的一致性和完整性。例如,在将资金从一个帐户转移到另一个帐户的银行应用中,一个帐户将一定的金额贷记到一个数据库表中,同时另一个帐户将相同的金额借记到另一个数据库表中。由于计算机可能会因停电、网络中断等而出现故障,因此有可能更新了一个表中的行,但没有更新另一个表中的行。如果数据库支持事务,则可以将数据库操作组成一个事务,以防止因这些事件而使数据库出现不一致。如果事务中的某个点发生故障,则所有更新都可以回滚到事务开始之前的状态。如果没有发生故障,则通过以完成状态提交事务来完成更新。在 ADO.NET 中,可以使用 Connection 和 Transaction 对象来控制事务。可以使用 Connection.BeginTransaction 启动本地事务。一旦开始一个事务,就可以使用 Command 对象的 Transaction 属性在该事务中登记命令。然后,可以根据事务组件的成功或失败情况,使用 Transaction 对象提交或回滚在数据源中所做的修改。还可以使用 Connection.EnlistDistributedTransaction 在现有的分布式事务中登记。在现有的分布式事务中登记可以确保当提交或回滚整个分布式事务时,也提交或回滚对数据源所作的代码修改。以下示例创建一个 OleDbConnection 和一个 OleDbTransaction。它还演示了如何使用 BeginTransaction、Commit 和 Rollback 方法。
public void RunOleDbTransaction(string myConnString){OleDbConnection myConnection = new OleDbConnection(myConnString);myConnection.Open();OleDbCommand myCommand = myConnection.CreateCommand();OleDbTransaction myTrans;
// Start a local transactionmyTrans = myConnection.BeginTransaction(IsolationLevel.ReadCommitted);// Assign transaction object for a pending local transactionmyCommand.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();}catch (OleDbException 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();}}
OleDbTransaction.Commit 方法?提交数据库事务。public vi
您可能关注的文档
- 《大学计算机基础》-网页设计和制作(2010).ppt
- 11174960238_开门红启动大会操作流程与主持词版本1.doc
- 20101208分析函数学习_oracle函数.doc
- 《法国第五共与国宪法》修改版.doc
- 《管理SQL Server 2005安全》练习.doc
- abklzdb一_个月瘦40斤暴瘦法(绝对不是广告,有关节食).doc
- A+期刊网址与投稿邮箱.doc
- 《光色彩 颜色》教学设计 (2).doc
- 《红忍 血河之舞》操作与流程攻略.doc
- 《护理教育学》试题与答案.doc
- 【创新设计】2013-2014学年高中地理湘教版必修三同步教学2-5矿产资源合理开发和区域可持续发.ppt
- c#数据类型转换,BYTE,float,double,char类型间转换方法.doc
- 【高考语文复习教案】(选修)2014届高三《语言文字应用》:3-1 字之初,本为画——汉字起源.doc
- C#中DBNull、Null、和String.Empty解释.doc
- 【每日一步】Tomcat 7七大特性:新特性和增强功能.doc
- 【综合概述】各种标识牌特点以与产品优势.doc
- c++程序人事管理People(人员)类.doc
- 0-3岁妈妈看:艾斯苔尔:在生活中享受童谣与故事.doc
- C++静态存储区 栈 堆区别.doc
- 1-2 第2节 细胞多样性和统一性与章测试.doc
文档评论(0)