7

我正在使用 NHibernate 进行一些测试,目前我有两个映射实体OrdersProducts。与往常一样,Order具有Products集合,我将其映射为:

<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>();

如果我在数据库中有一个持久订单(约翰的订单),其Products集合中有一些项目(一个苹果、一个橙子和一个椰子),我尝试向集合中添加一个新项目(一个香蕉)我可以看到从 NHibernate 正在执行如下操作的 SQL 输出中:

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, Product_ID) VALUES (@Johns_Order_ID, @Orange_ID)
INSERT INTO Products (Order_ID, Product_ID) VALUES (@Johns_Order_ID, @Coconut_ID)
INSERT INTO Products (Order_ID, Product_ID) VALUES (@Johns_Order_ID, @Banana_ID)

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

INSERT INTO Products_Table (Product_Name, Product_ID) VALUES ('Banana', @Banana_ID)
INSERT INTO Products (Order_ID, Product_ID) VALUES (@Johns_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();
}
4

1 回答 1

5

SO上有一个类似的问题:NHibernate Many-To-Many Is Deleting All Associations Before Inserting

从 NHibernate 的文档

包是最坏的情况。由于包允许重复的元素值并且没有索引列,因此可以不定义主键。NHibernate 无法区分重复的行。NHibernate 通过完全删除(在单个 DELETE 中)并在集合发生更改时重新创建集合来解决此问题。这可能是非常低效的。

于 2012-06-08T21:14:05.153 回答