ASP.NET Core 1.0: Using Entity Framework Core 1.0 - Transaction
2016-06-03 10:27
886 查看
跟Entity Framework之前的版本不同,Class DbContext不再有AcceptAllChanges()方法。
使用Transaction需要使用DbContext中的Database对象。
当然要使用async,必须将对应的Method做调整
为:
值得强调一下的是,AcceptAllChanges()方法还是存在的,只不过移到了ChangeTracker上了。
看看DbContext的定义
使用AcceptAllChanges()的实例:
使用ChangeTracker.AcceptAllChanges()方法有个问题,就是设置为Identity的Column不会自动获取ID,因为SaveChanges(false)表示不向数据库提交修改。对SQL Server来说,只有SaveChanges(),EntityFramework才会调用SCOPE_IDENTITY()来获取下一个ID。
是为之记。
Alva Chien
2016.6.3
使用Transaction需要使用DbContext中的Database对象。
using (var transaction = await _dbContext.Database.BeginTransactionAsync()) { try { ... Operation on object _dbContext.TableA.Add(rowa); // Add rowa to Table A _dbContext.SaveChanges(); _dbContext.TableB.Add(rowb); // Add rowb to Table B _dbContext.SaveChanges(); transaction.Commit(); } catch (Exception exp) { #if DEBUG Console.WriteLine(exp.Message); #endif transaction.Rollback(); }
当然要使用async,必须将对应的Method做调整
[HttpPost] public IActionResult Create([FromBody] MyViewModel ch)
为:
[HttpPost] public async Task<IActionResult> Create([FromBody] MyViewModel ch)
值得强调一下的是,AcceptAllChanges()方法还是存在的,只不过移到了ChangeTracker上了。
看看DbContext的定义
public class DbContext : IDisposable, IInfrastructure<IServiceProvider> { public DbContext([NotNullAttribute] DbContextOptions options); protected DbContext(); public virtual ChangeTracker ChangeTracker { get; } public virtual DatabaseFacade Database { get; } ... }
使用AcceptAllChanges()的实例:
// Some tables changed _dbContext.SaveChanges(false); // Other tables changed _dbContext.SaveChanges(false); // Now save it. _dbContext.ChangeTracker.AcceptAllChanges();
使用ChangeTracker.AcceptAllChanges()方法有个问题,就是设置为Identity的Column不会自动获取ID,因为SaveChanges(false)表示不向数据库提交修改。对SQL Server来说,只有SaveChanges(),EntityFramework才会调用SCOPE_IDENTITY()来获取下一个ID。
是为之记。
Alva Chien
2016.6.3
相关文章推荐
- 分享微信开发Html5轻游戏中的几个坑
- 星外ASP.Net的安全设置相关说明
- C#、ASP.NET通用扩展工具类之TypeParse
- 实现ASP.NET无刷新下载并提示下载完成的开发思路
- C#、ASP.NET通用扩展工具类之LogicSugar
- C#、ASP.NET通用工具类IsWhat?(可以判断数字、身份证、数据类型等等)
- 程序中常用的种代码
- ASP.NET、ASP、PHP、JSP之间有什么区别?
- 在ASP.NET 2.0中操作数据之六十六:在TableAdapters中使用现有的存储过程
- ASP.NET页面间的传值的几种方法
- 在ASP.NET 2.0中操作数据之二十四:分页和排序报表数据
- 入侵ASP.net网站的经验附利用代码
- 盘点PHP和ASP.NET的10大对比!
- 在ASP.NET 2.0中操作数据之四十八:对SqlDataSource控件使用开放式并发
- ASP.NET MVC4入门教程(四):添加一个模型
- 在ASP.NET 2.0中操作数据之二十三:基于用户对修改数据进行限制
- 在ASP.NET 2.0中操作数据之七十三:用Managed Code创建存储过程和用户自定义函数(上部分)
- ASP.NET MVC4入门教程(五):从控制器访问数据模型
- 在ASP.NET 2.0中操作数据之六十七:在TableAdapters中使用JOINs
- ASP.NET中 CheckBox复选框控件的使用