小白面试:EF Core的三种事务

有一次小白面试回来说,面试官问EF Core怎么实现,他当时懵逼了,之前写过但是长时间不用了,最近的事务还是用第三方封装的方法,早忘记原生的怎么写了。本文将替小白回答这个问题,而且有三种实现方法。

    事务这个功能一般在批量插入或者修改多个数据表时用到,操作过程中要么都成功,要么都失败,来保证数据的一致性。使用场景比如支付转账、图书馆借书书等。EF Core有三种以上的方法实现,本文介绍比较通用的三种方法。

一、SaveChanges(默认事务)

    在默认的情况下,如果使用EF的SavaChanges操作多表或多条数据的保存,它是支持事务的。当然如果不想用也可以关闭默认的事务。上代码

查看代码
 using (ApplicationDbContext db=new ApplicationDbContext(options))
 {
     try
     {
         //关闭SaveChanges的默认事务 事务就不会起作用
         // db.Database.AutoTransactionsEnabled = false;
         db.Customers.Add(new Customer() { Name = "梁朝伟", Age = 11, Email = "lcw@qq.com" });
         db.Customers.Add(new Customer() { Name = "张曼玉", Age = 55, Email = "zmy@qq.com" });
         db.SaveChanges();//
     }
     catch (Exception)
     {
         Console.WriteLine("如果出错了,两条数据都没有执行成功");
     }
 }

二、DbContextTransaction(BeginTransaction)

BeginTransaction也是常用的事务,在ADO.NET中也可以使用(SqlBeginTransaction)。功能有开启事务、Commit提交事务、Rollback回滚事务、Dispose销毁,用Using包裹的话,就不需要写Rollback关键字,它会自动回滚。如果不用Using包裹事务,就需要在Catch中手动RollBack回滚,并且最好最后手动的Dispose一下。上代码

查看代码
 using (ApplicationDbContext db = new ApplicationDbContext(options))
 {
     using(var transaction= db.Database.BeginTransaction())
     {
         try
         {
             db.Customers.Add(new Customer() { Name = "梁朝伟", Age = 11, Email = "lcw@qq.com" });
             db.SaveChanges();
             db.Customers.Add(new Customer() { Name = "张曼玉", Age = 55, Email = "zmy@qq.com" });
             db.SaveChanges();
             //提交事务
             transaction.Commit();
         }
         catch (Exception)
         {
             //回归事务,在try不需要,报错后不会提交事务
             //transaction.Rollback();
             //transaction.Dispose();
         }
        
     }
 }

三、TransactionScope(环境事务)

 TransactionScope是.Net 2.0之后的新特征,它的用途是为数据库访问提供了一个“轻量级”[区别于:SqlTransaction]的事物。功能有Complete提交事务、 Transaction.Current.Rollback()回滚事务、Dispose销毁对象。跟BeginTransaction一样如果用Using包裹的话不需要写回滚和销毁。上代码:

查看代码
 using (ApplicationDbContext db = new ApplicationDbContext(options))
 {
     using (var scope = new TransactionScope())
     {
         try
         {
             db.Customers.Add(new Customer() { Name = "梁朝伟", Age = 11, Email = "lcw@qq.com" });
             db.SaveChanges();
             db.Customers.Add(new Customer() { Name = "张曼玉", Age = 55, Email = "zmy@qq.com" });
             db.SaveChanges();
             //提交事务
             scope.Complete();
         }
         catch (Exception)
         {
         }
 
 
     }
 }

结语

    上面列举了EF Core的三种事务的使用,案例是比较简单的用法,具体还有多上下文的事务、分布式事务等,由于篇幅有限大家自己可以研究一下,本案例仅供参考,具体根据您的项目来实践。再来说一下面试,问这种问题主要是考察你对代码的熟悉程度,一般长时间不用一时想不起很正常,并不代表你不会。希望本文对你有所帮助,欢迎留言和提出异议。

posted on 2023-02-10 15:09  静以修身俭以养德  阅读(307)  评论(0编辑  收藏  举报

导航