0

使用集合上的单向映射和 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();
                }
            }
        }
    }
4

1 回答 1

0

看起来您没有在Order映射类中映射Account__id列。试着放

Map(x => x.Account_id)

到您的 OrderMap 类。

于 2012-07-31T10:27:08.380 回答