在 Entity Framework 中,我想使用两个外键作为另一个实体类型的主键。
public class CustomerExtensionValue {
// Values for extended attributes of a customer
[Key]
[Column(Order = 0)]
public Customer Customer { get; set; }
[Key]
[Column(Order = 1)]
public CustomerExtension Extension { get; set; }
[Required]
public string Value { get; set; }
}
但是,这会给我一个错误,提示缺少 key 。 \tSystem.Data.Entity.Edm.EdmEntityType::EntityType“CustomerExtensionValue”没有定义键。为此 EntityType 定义键。
我知道我可以再定义两个属性来保存所引用实体类型的主键。 Visual Studio 不够聪明,无法自己使用它们的主键吗?
最佳答案
主键必须始终由实体类中的标量属性定义。您不能仅通过导航属性引用 PK。在您的模型中,需要这样的定义:
public class CustomerExtensionValue {
[Key, ForeignKey("Customer"), Column(Order = 0)]
public int CustomerId { get; set; }
[Key, ForeignKey("Extension"), Column(Order = 1)]
public int ExtensionId { get; set; }
public Customer Customer { get; set; }
public CustomerExtension Extension { get; set; }
[Required]
public string Value { get; set; }
}
关于c# - 在 Entity Framework 中将两个外键定义为主键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22008285/