首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >带有事务的EF 6 SaveChanges

带有事务的EF 6 SaveChanges
EN

Stack Overflow用户
提问于 2015-12-11 12:20:23
回答 1查看 1.1K关注 0票数 1

当试图保存一个全新的对象树时,我有以下问题。

我已经创建了一个带有许多子对象的对象。子对象都是创建的初始对象的1层深度。我的问题是,我试图创建的一个子对象也有一个FK到另一个子对象中。因此,在最初创建这些对象时,FK的值当然是0,因为尚未创建的子对象的PK当前为0。当我在上下文中调用SaveChanges时,它会出错,因为键对依赖于另一个子对象的存在的子对象是不确定的。这是一个相当大的对象树,因此我似乎需要先保存父对象,然后保存其他对象,这样我才能获得新的PK值,用于那些依赖于其他表的表。问题是我想要一个全部或不存在的情况,所以我想要所有的对象保存或者不保存。EF 6中的SaveChanges取消了将false作为参数传递的能力,然后调用SaveAllChanges()。我现在最好的办法是让这件事起作用?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-12-11 12:39:29

你应该使用交易。在事务处理中,应该首先向dbset添加父对象,并使用Context.SaveChanges() --在提交事务之前,不能在db上创建实体。但是,它将保留id(主键)。所以您可以在子对象上使用这个id。如果需要id(主键),则可以对子对象执行同样的操作,请使用Context.SaveChanges()

代码语言:javascript
运行
复制
using (var myTransaction = Context.Database.BeginTransaction())
                {
                    try
                    {
                       //Crate Parent Object
                       Context.SaveChanges();
                       //Create Child Object;
                           Context.SaveChanges();
                           //Other Childs
                             Context.SaveChanges();
                             //If everything goes well
                             myTransaction.Commit();
                    }
                    catch (Exception)
                    {
                        myTransaction.Rollback();
                    }
                }
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34223429

复制
相关文章

相似问题

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