Code First
与我一起使用EF 5.0
有以下内容:
internal class Entities : DbContext
{
public DbSet<User> Users { get; set; }
public DbSet<Project> Projects { get; set; }
}
// User class which holds a list of 'Project' class
public class User
{
private List<Project> _projects = new List<Project>();
public int Id { get; set; }
internal List<Project> Projects
{
get { return _projects; }
set { _projects = value; }
}
}
// Project class which holds a list of 'Milestone' class
public class Project
{
private List<Milestone> _milestones = new List<Milestone>();
public int Id { get; set; }
public string Title { get; set; }
internal List<Milestone> MileStones
{
get { return _milestones; }
set { _milestones = value; }
}
}
尽管 EF 已正确创建表和关系(一对多:User=>Project=>Milestone),但如果我创建一个包含一些项目的用户并将其添加到DbContext
,则只有该用户将被添加,而他的项目不会. 对于具有里程碑的项目的用户也是如此。我是这样做的:
public void AddUser(User user)
{
using (var repository = new Entities())
{
repository.Users.Add(user);
repository.SaveChanges();
}
}
我的问题是如何强制EF
自动插入或更新复杂实体(级联),从而添加具有项目列表的用户,在 USERS 表中自动插入用户,在 PROJECTS 表中自动插入他的项目(具有正确的关系)?
在它的第 5 个版本中是EF
聪明的还是我应该手动做?