c# – 当我向其中添加一个项目时,为什么NHibernate会删除并重新创建集合中的所有关联?

我正在使用NHibernate进行一些测试,我目前有两个映射实体,Orders和Products.一如既往,Order有一系列产品,我将其映射为:
<bag name="Products" cascade="all" lazy="true">
  <key column ="Order_ID" />
  <many-to-many class="Product" column="Product_ID" />
</bag>

在C#方面:

public virtual IList<Product> Products
{
    get { return _Products; }
    set { _Products = value; }
}
private IList<Product> _Products = new List<Product>();

如果我在数据库中有一个持久订单(约翰的订单),其产品集合中有一些项目(苹果,橙子和椰子),我尝试在集合中添加一个新项目(香蕉)我可以看到从sql输出中,NHibernate正在做这样的事情:

INSERT INTO Products_Table (Product_Name,Product_ID) VALUES ('Banana',@Banana_ID)
DELETE FROM Products WHERE Order_ID = @Johns_Order_ID
INSERT INTO Products (Order_ID,Product_ID) VALUES (@Johns_Order_ID,@Apple_ID)
INSERT INTO Products (Order_ID,@Orange_ID)
INSERT INTO Products (Order_ID,@Coconut_ID)
INSERT INTO Products (Order_ID,@Banana_ID)

而不是简单地做这样的事情:

INSERT INTO Products_Table (Product_Name,@Banana_ID)
INSERT INTO Products (Order_ID,@Banana_ID)

那么为什么NHibernate会删除Products表中的所有关联,以便在我只是尝试在其中插入新产品时再次重新创建它们?怎么避免呢?

提前致谢!

PS:我试图使用这个SO Question中建议的逆映射属性,但即使新产品被保存,它与订单的关联也没有.

编辑:

这是我用来修改产品列表的代码

Order order = session.Load<Order>(orderId);
order.Products.Add(new Product() { Name = "Banana" });
using (ITransaction transaction = session.BeginTransaction())
{
    session.Update(order);
    transaction.Commit();
}

解决方法

在SO: NHibernate Many-To-Many Is Deleting All Associations Before Inserting上已经存在类似的问题

来自NHibernate的documentation

Bags are the worst case. Since a bag permits duplicate element values and has no index column,no primary key may be defined. NHibernate has no way of distinguishing between duplicate rows. NHibernate resolves this problem by completely removing (in a single DELETE) and recreating the collection whenever it changes. This might be very inefficient.

相关文章

C#项目进行IIS部署过程中报错及其一般解决方案_c#iis执行语句...
微信扫码登录PC端网站应用的案例(C#)_c# 微信扫码登录
原文地址:http://msdn.microsoft.com/en-us/magazine/cc163...
前言 随着近些年微服务的流行,有越来越多的开发者和团队所采...
最近因为比较忙,好久没有写博客了,这篇主要给大家分享一下...
在多核CPU在今天和不久的将来,计算机将拥有更多的内核,Mic...