【问题标题】:Defining two foreign keys as primary key in Entity Framework在实体框架中定义两个外键为主键
【发布时间】:2014-02-26 00:47:45
【问题描述】:

在实体框架中,我想使用两个外键作为另一种实体类型的主键。

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; }
}

但是,这给了我一个错误,即缺少密钥。 \tSystem.Data.Entity.Edm.EdmEntityType: : EntityType 'CustomerExtensionValue' has no key defined. Define the key for this EntityType.

我知道我可以再定义两个属性来保存被引用实体类型的主键。 Visual Studio 是否不够聪明,无法自己使用主键?

【问题讨论】:

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


【解决方案1】:

主键始终必须由实体类中的标量属性定义。您不能仅通过导航属性来引用 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; }
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2011-07-20
    • 1970-01-01
    • 1970-01-01
    • 2012-03-26
    • 1970-01-01
    • 1970-01-01
    • 2013-01-15
    • 1970-01-01
    相关资源
    最近更新 更多