如何使这个基础 class 首先与 Entity Framework 6.1 代码一起工作
How to make this base class work with Entity Framework 6.1 code first
我有一个基础 class,看起来像这样:
public abstract class BaseEntity
{
[Required]
public DateTime Created { get; set; }
public DateTime Modified { get; set; }
[Required]
public int CreatedByUserId { get; set; }
public int ModifiedByUserId { get; set; }
[ForeignKey("CreatedByUserId")]
public virtual User CreatedBy { get; set; }
[ForeignKey("ModifiedByUserId")]
public virtual User ModifiedBy { get; set; }
}
我想用这个 class 作为所有其他 class 的基础。同样对于用户 class,因为用户是由其他用户创建和修改的。
public class User : BaseEntity
{
[Key]
public int UserId { get; set; }
....
}
但是我得到这个错误:
必须使用流畅的关系 API 或数据注释显式配置此关联的主要端。
我研究了这个错误,一切都变得很清楚了。必须告知 EF 这些实体彼此之间的关系,以及先保存哪个实体,然后再保存哪个实体。但是在所有examples/solutions中,我没有找到类似的案例。谁能帮我解决这个问题?我更愿意通过使用数据注释来解决这个问题。
嗯,我不知道有什么好的数据注释解决方案,但使用 Fluent API 可以以非常清晰的方式帮助您。您应该在 DbContext class
中覆盖 OnModelCreating 方法
public class MyDbContext : DbContext
{
DbSet<User> Users { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<User>()
.HasRequired<User>(x => x.CreatedBy)
.WithMany();
modelBuilder.Entity<User>()
.HasRequired<User>(x => x.ModifiedBy)
.WithMany();
}
}
这就是描述两个自引用一对多关系的方式。
我有一个基础 class,看起来像这样:
public abstract class BaseEntity
{
[Required]
public DateTime Created { get; set; }
public DateTime Modified { get; set; }
[Required]
public int CreatedByUserId { get; set; }
public int ModifiedByUserId { get; set; }
[ForeignKey("CreatedByUserId")]
public virtual User CreatedBy { get; set; }
[ForeignKey("ModifiedByUserId")]
public virtual User ModifiedBy { get; set; }
}
我想用这个 class 作为所有其他 class 的基础。同样对于用户 class,因为用户是由其他用户创建和修改的。
public class User : BaseEntity
{
[Key]
public int UserId { get; set; }
....
}
但是我得到这个错误:
必须使用流畅的关系 API 或数据注释显式配置此关联的主要端。
我研究了这个错误,一切都变得很清楚了。必须告知 EF 这些实体彼此之间的关系,以及先保存哪个实体,然后再保存哪个实体。但是在所有examples/solutions中,我没有找到类似的案例。谁能帮我解决这个问题?我更愿意通过使用数据注释来解决这个问题。
嗯,我不知道有什么好的数据注释解决方案,但使用 Fluent API 可以以非常清晰的方式帮助您。您应该在 DbContext class
中覆盖 OnModelCreating 方法 public class MyDbContext : DbContext
{
DbSet<User> Users { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<User>()
.HasRequired<User>(x => x.CreatedBy)
.WithMany();
modelBuilder.Entity<User>()
.HasRequired<User>(x => x.ModifiedBy)
.WithMany();
}
}
这就是描述两个自引用一对多关系的方式。