我正在尝试使用EF将产品与交易联系起来。目前,它只允许我将同一笔交易映射到产品上一次。
例如,在事务中,尝试添加两个相同的产品不起作用。它只会存储一个映射?
有可能这样做吗?或者我应该创建一个解决方法?
答案 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; }
}