1

我正在尝试使用 Fluent API(实体框架 v5)在以下域类之间建立外键关系:

public partial class User
{
    public long UserID { get; set; }
    public string UserName { get; set; }
}
public partial class AccountGroup : BaseEntity
{
    public long AccountGroupID { get; set; }
    public string Name { get; set; }
    public long ModifiedBy { get; set; }
    public virtual User User { get; set; }
}

流畅的 API

builder.Entity<User>().HasKey(p => p.UserID); //Set User Id as primary key
builder.Entity<AccountGroup>().HasKey(x => x.AccountGroupID); //SetAccountGroupId as PK

我不确定如何使用流利的 API 设置 User.UserId 和 AccountGroup.ModifiedBy 列之间的关系。我可以通过 Data Annotation 做到这一点,但我正在寻找使用 fluent api 的解决方案

4

1 回答 1

3

从您的实体中删除 ModifiedBy 属性:

public partial class AccountGroup
{
    public long AccountGroupID { get; set; }
    public string Name { get; set; }
    public virtual User User { get; set; }
}

然后像这样映射外键:

builder.Entity<AccountGroup>()
    .HasRequired(x => x.User)
    .WithMany()
    .Map(m => m.MapKey("ModifiedBy"));

如果外键可以为空,请改用 HasOptional:

builder.Entity<AccountGroup>()
    .HasOptional(x => x.User)
    .WithMany()
    .Map(m => m.MapKey("ModifiedBy"));

您也不需要像您一样指定主键。实体框架将按照惯例发现这些。

于 2013-07-18T15:26:43.043 回答