我有当前的情况:
我首先使用EF6代码,并创建了类似这样的数据模型:
public class MainObject{
..some properties
IList<SubObject> SubObjects{get;set;}
}
public class SubObject{
..some properties
IList<SubSubObject> SubSubObjects{get;set;}
}
public class SubObject{
..some properties
IList<SubObject> SubObjects{get;set;}
}
所以基本上我有一个主对象,它有0到多个子对象,并且子对象和子对象之间存在多对多的关系。
我正在创建一个MVC应用程序,所以我的正常程序流程是用户请求一个基本上使用MainObject作为其数据模型的页面。然后,用户与页面交互并根据需要更改,添加或删除子对象和子对象,然后单击“保存”。在保存时,对象图被发送回控制器,并且根据用户在客户端进行的更改看起来是正确的。现在我的问题如下:
如何以良好的方式将其存储回数据库。
我需要将我的对象附加到上下文中,但我不知道哪些对象是新的,修改过的或删除的。
我已经编写了一些现在部分有效的代码,但它变得如此丑陋以至于我真的不想走这条路。是否有可能以某种方式从数据库中获取相关的对象图,并让EF将两个图相互比较,然后将相关的更改保存到数据库中?
非常感谢任何使这种更顺畅的帮助。
答案 0 :(得分:7)
我最终使用GraphDiff为我解决了这个问题,而且效果很好!这真的应该建立在EF中,但是直到它,它仍然是一个很好的替代品。
要解决上面问题中给出的示例,这将确保分离的图形得到正确保存(假设我有一个MainObject
我想保存名为main):
context.UpdateGraph(main, map =>map
.AssociatedCollection( m => m.SubObjects, with => with
.AssociatedCollection( s => s.SubSubObjects)
)
);
context.SaveChanges();