gpt4 book ai didi

c# - 在 Entity Framework 中将两个外键定义为主键

转载 作者:行者123 更新时间:2023-11-30 14:10:52 25 4
gpt4 key购买 nike

在 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/

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