EF 中事务的书写

2018-06-22 07:31:18来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

在EF 中怎么使用事务?

这个问题纠结了我好久,直到有人跟我一起讨论,我和同事一起讨论查资料。

查的好多资料都是使用

using (TransactionScope scope = new TransactionScope())  
{  
  //具体代码内容
    scope.Complete();  
}  

这种方式。
而我在实际使用中是没法使用的。

所以我就一直找其他的方式,无意中看到某个网站的的database,然后我就采用了下面的方式:

 1 using (var dbContext = new TopOnlineDbContext())
 2             {
 3                 using (var scope = dbContext.Database.BeginTransaction())
 4                 {
 5                     try
 6                     {
 7                         if (ids != null)
 8                         {
 9                             foreach (var id in ids)
10                             {
11                                 T t = dbContext.Find<T>(id);
12                                 assfeedback.IsDel = true;
13                                 dbContext.Update<T>(t);
14                             }
15                         }
16                         scope.Commit();//正常完成就可以提交
17                         return 0;
18                     }
19                     catch (Exception ex)
20                     {
21                         scope.Rollback();//发生异常就回滚
22                         return -1;
23                     }
24                 }
25             }

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:文本框,下拉框,单选框只读状态属性

下一篇:log4net保存到数据库系列二:独立配置文件中配置log4net