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

标签 c# entity-framework asp.net-web-api

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

相关文章:

c# - 验证标签内容等于 null 或 string.Empty

entity-framework - EF 4.2 代码优先和 DDD 设计问题

c# - Code First 自动迁移

asp.net-web-api - ASP.NET Web API 和授权

c# - C# 中最简单的控制台串口程序

c# - 如何封装存储过程调用

c# - md5哈希混淆

c# - 验证 DataGridView Windows 窗体

xml - 使用 XML 文档部署 Web API 项目时生成服务器上的 "Access is denied"

logging - ASP.NET MVC 4 Web API : Diagnostic features