在Code-First Entity Framework中包含复合主键中的外键

时间:2015-06-16 05:55:39

标签: c# entity-framework foreign-keys primary-key composite-primary-key

我有一个名为Member的实体,我想为其设置MemberIdGroupId的主键。在这种情况下,GroupId是实体Group的主键。使用下面的代码,外键设置正确,但它不包含在主键的一部分中。如何添加外键列以生成复合主键?

public class Member
{
    [Key]
    public string MemberId { get; set; }

    public string MemberName { get; set; }

    public string GroupId { get; set; }

    [ForeignKey("GroupId")]
    public virtual Group Group { get; set; }
}

1 个答案:

答案 0 :(得分:7)

以下是MSDN的示例。只需在要包含在组合键中的所有属性上使用[Key]注释,并为这些列添加额外的[Column(Order=x)]属性。

public class Member
{
    [Key]
    [Column(Order = 0)]
    public string MemberId { get; set; }

    [Key]
    [Column(Order = 1)]
    public string GroupId { get; set; }

    public string MemberName { get; set; }     

    [ForeignKey("GroupId")]
    public virtual Group Group { get; set; }
}