2016-11-14 67 views
0

下面是我的父子关系类和映射。我们在我们的项目中使用Nhibernate 4.0.0.4000。当我打电话session.Merge(家长)来更新它有一个新的子对象插入到数据库父。它引发无法为子对象中的code_column插入Null异常。有人可以指导我的映射器代码中的哪一部分是错误的吗?NHibernate的一对多的关系复合关键问题

Public class parent { 
    public virtual string Code { get; set; } 
    public virtual string Desc { get; set; } 
    public virtual IList<Child> Children{ get; set; } 
    public virtual int version {get;set;} 
} 

Public class Child { 
    public virtual parent ParentObj{ get; set; } 
    public virtual string Code1{ get; set; } 
    public virtual string Code2{ get; set; } 
    public virtual int version {get;set;} 
} 


public class ParentMap : ClassMap<Parent> { 
public ParentMap() { 
    Table("Parent_Table"); 
      LazyLoad(); 
      OptimisticLock.Version(); 

    Id(x => x.Code) 
      .Column("Code_Column") 
      .Index("Code_IDX1") 
      .Length(5) 
      .Unique() 
      .GeneratedBy.Assigned() 
      .Not.Nullable(); 

      Version(x => x.Version) 
       .Column("VERS") 
       .UnsavedValue("0"); 

      HasMany(x => x.Children) 
        .AsBag() 
       .KeyColumn("Code_Column") 
       .Inverse() 
       .LazyLoad() 
       .Cascade.All(); 
} 

} 


public class ChildMap: ClassMap<Child> { 
public ChildMap() { 
Table("Child_Table"); 
      LazyLoad(); 
      OptimisticLock.Version(); 

      CompositeId() 
       .KeyReference(u => u.Code, "Code_Column") 
       .KeyProperty(u => u.Code1, "CODE1_column") 
       .KeyProperty(u => u.Code2, "CODE2_column"); 

      Version(x => x.Version) 
      .Column("VERS") 
      .UnsavedValue("0"); 
} 

} 
+0

在运行时,你的子对象有正确的,非空,参考其母公司? –

+0

您好大卫,谢谢你的邀请,这是在运行time.It正确的是复合标识它曾与session.merge方法可能因为延迟加载的问题。下面的文章很好地解释了这个问题和解决方案。我通过为复合标识创建一个单独的类跟踪相同,它工作正常。 http://nhibernate.info/blog/2010/06/30/nhibernate-and-composite-keys.html – Babu

回答

0

这是复合标识它曾与session.merge方法可能因为延迟加载的问题。当你有组合键,组合键创建一个类,并利用它们在你的实体这将很好地工作。