实体框架 - 许多多对多关系

时间:2012-01-22 00:10:35

标签: asp.net-mvc-3 entity-framework many-to-many

我正在尝试使用EF将产品与交易联系起来。目前,它只允许我将同一笔交易映射到产品上一次。

例如,在事务中,尝试添加两个相同的产品不起作用。它只会存储一个映射?

有可能这样做吗?或者我应该创建一个解决方法?

1 个答案:

答案 0 :(得分:1)

EF不允许您向多对多关系添加重复项。连接表应该只包含参与表的主键作为表的PK。

您可以通过将连接表映射为实体并创建自动递增的ID作为连接表的PK来解决此问题。

public class ProductTransaction
{
    [Key]
    public int Id { get; set; }

    public int ProductId { get; set; }

    public int TransactionId { get; set; }

    public Product Product { get; set; }

    public Transaction Transaction { get; set; }
}

public class Product
{
    [Key]
    public int Id { get; set; }

    public virtual ICollection<ProductTransaction> Transactions { get; set; }
}

public class Transaction
{
    [Key]
    public int Id { get; set; }

    public virtual ICollection<ProductTransaction> Products { get; set; }
}