.net EF 事务TransactionScope和BeginTransaction的用法

1 篇文章 0 订阅
1 篇文章 0 订阅

 
事务就是确保一次数据库操作,所有步骤都成功,如果哪一步出错了,整个操作都将回滚。在EF使用事务有两种方案,一种是EF自带的.BeginTransaction()方法,另一种是使用TransactionScope类。
 

TransactionScope

using (var scope = new TransactionScope(TransactionScopeAsyncFlowOption.Enabled))
{
    scope.Complete();
}            
using (var db = new DBModel())
{
    using (var tran = new TransactionScope())   //开启事务
    {
        var student = db.students.FirstOrDefault(s => s.name == "萝莉");
        db.students.Remove(student);    //删除萝莉

        db.SaveChanges();

        tran.Complete();  //必须调用.Complete(),不然数据不会保存
    }//出了using代码块如果还没调用Complete(),所有操作就会自动回滚
}


TransactionScope事务类,它可以使代码块成为事务性代码。并自动提升为分布式事务 优点:实现简单,同时能够自动提升为分布式事务 

 

BeginTransaction

 

using (var context = new BloggingContext())
{
    using (var dbContextTransaction = context.Database.BeginTransaction())
    {
        try{
            sqlTxn.Commit();
        }
        catch (Exception)
        {
            sqlTxn.Rollback();
        }
    }
}

using (var db = new DBModel())
{
    var tran = db.Database.BeginTransaction();  //开启事务

    try
    {
        var student = db.students.FirstOrDefault(s => s.name == "萝莉");
        db.students.Remove(student);    //删除萝莉

        db.SaveChanges();

        tran.Commit();  //必须调用Commit(),不然数据不会保存
    }
    catch (Exception ex)
    {
        tran.Rollback();    //出错就回滚
    }
}

 

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值