我正在使用 NHibernate 进行一些测试,目前我有两个映射实体Orders和Products。与往常一样,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();
}