首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >TransactionScope和BeginTransaction

TransactionScope和BeginTransaction
EN

Stack Overflow用户
提问于 2017-05-29 12:56:36
回答 1查看 103关注 0票数 0

在EF6,MVC,MySQL场景中,使用EF TransactionScopeDBContext.BeginTransaction有什么不同?TransactionScope中没有显式回滚。

应该是吗?

代码语言:javascript
复制
using transactionscope
{
   using dbContext
   {
        .........
        .........
        dbContext.SaveChanges();
        .............
        .......
        dbContext.SaveChanges();
   }
   transactionscope.Complete();
  // there is no .Rollback method
}

代码语言:javascript
复制
using dbContext
{
   using dbtx = dbContext.Database.BeginTransaction
   {
        .........
        .........
        dbContext.SaveChanges();
        .............
        .......
        dbContext.SaveChanges();
        dbtx.Commit()
        // and dbtx.Rollback()  when exception occurs
   }

}

有什么关系?

EN

回答 1

Stack Overflow用户

发布于 2017-06-02 04:59:14

我不会注意其中的区别。我不会担心隔离级别。执行以下操作:全部回滚(不需要显式回滚)或全部提交:

代码语言:javascript
复制
using (TransactionScope scope = new TransactionScope())
{
    ...
    db.SaveChanges();

    ...
    db.SaveChanges();
    scope.Complete();
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44234861

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档