gpt4 book ai didi

c# - 在代码优先 Entity Framework 中将外键包含在复合主键中

转载 作者:太空狗 更新时间:2023-10-29 21:22:03 24 4
gpt4 key购买 nike

我有一个名为 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; }
}

最佳答案

这是来自 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; }
}

关于c# - 在代码优先 Entity Framework 中将外键包含在复合主键中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30859790/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com