使用集合上的单向映射和 Cascade.All ,是否可以通过设置有效的 FK 然后执行 Save 或 SaveOrUpdate 只保存一个孩子?
如果我创建一个新订单,设置一个有效的 Account_id并执行 SaveOrUpdate,则 Account_id在数据库中设置为 NULL,而实体仍然具有先前设置的 Account_id。
为什么?我可以修改 SaveOrUpdate 方法以使其工作吗?
public class Account
{
public int Id { get; set; }
public string Name { get; set; }
public IList<Order> Orders { get; set; }
//...
}
public class Order
{
public int Id { get; set; }
public int Account__id { get; set; }
public decimal Price { get; set; }
//...
}
映射:
public class AccountMap : ClassMap<Account>
{
public AccountMap()
: base()
{
Id(x => x.Id).GeneratedBy.Identity();
Map(x => x.Name);
HasMany(x => x.Orders).KeyColumn("Account__id").Cascade.All();
}
}
存储库:
public void SaveOrUpdate(T instance)
{
using (ISession session = FnhManager.OpenSession())
{
using (ITransaction transaction = session.BeginTransaction())
{
lock (instance)
{
session.SaveOrUpdate(instance);
transaction.Commit();
}
}
}
}