首页 > 其他 > 详细

transactionscope报“此操作对该事务的状态无效”问题

时间:2018-04-12 15:57:23      阅读:1266      评论:0      收藏:0      [点我收藏+]

一,可能出现事务时间过短造成的问题,这时我们需要延长时间:如下代码

using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required, new TimeSpan(6000000000)))
 {
   //保存内容
 scope.Complete();
 }

二,可能是由于你调用的方法问题,由于两个方法操作了不同的数据库,这时你就需要事务内嵌,TransactionScopeOption.RequiresNew这个是重点,代码如下

          using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required))
          {
                Event en = new English();         //这里执行一个操作,读取一个数据库的数据如(DB1)
                en.Say(); 
                using (TransactionScope scope2 = new TransactionScope(TransactionScopeOption.RequiresNew))
                {
                    Event ch = new Chinese();    //这里执行一个操作,读取第二个数据库的数据(DB2)
                    ch.Say();
                    scope2.Complete();
                }
                scope.Complete();
            }

 

transactionscope报“此操作对该事务的状态无效”问题

原文:https://www.cnblogs.com/May-day/p/8808230.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!