我只是在为实体框架使用这个Code First example,遇到了一个我不理解的问题。假定POCO对象和数据库上下文与示例中相同,并且在应用程序的入口点中具有以下代码:
var blog = new Blog { Name = "My Blog" };
var post = new Post {Title = "A Random Post", Blog = blog};
blog.Posts = new List<Post> {post};
db.Blogs.Add(blog);
var blog2 = new Blog {Name = "Another Blog", Posts = new List<Post> {post}};
db.Blogs.Add(blog2);
db.SaveChanges();
// Display all Blogs from the database
var query = from b in db.Blogs
orderby b.Name
select b;
Console.WriteLine("All blogs in the database:");
foreach (var item in query)
{
Console.WriteLine(item.Name);
foreach (var p in item.Posts)
{
Console.WriteLine(p.Title);
}
}
为什么两个博客中都引用的帖子仅出现在第二个博客中?每次向数据库添加内容时都必须调用
SaveChanges
吗? 最佳答案
帖子只能属于一个博客。通过将其添加到第二个博客的帖子列表中,对第一个博客的引用将被覆盖。
关于c# - Entity Framework 在不同集合中多次引用同一对象,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/17088551/