我的数据模型看起来像这样。
public abstract class BasePivotField
{
public virtual int SystemId { get; set; }
public virtual int Version { get; set; }
public virtual string FieldName { get; set; }
public virtual string FieldValuePrefix { get; set; }
public virtual Field Field { get; set; }
public abstract PivotFieldType FieldType { get; }
}
public class PivotColumnField : BasePivotField
{
public virtual CriteriaWithField FieldCriteria { get; set; }
public virtual int Width { get; set; }
public override PivotFieldType FieldType
{
get { return PivotFieldType.ColumnField; }
}
}
public class PivotTableControl : BaseControl
{
public virtual Criteria Criteria { get; set; }
public virtual int Height { get; set; }
public virtual PagingProperties PagingProperties { get; set; }
public virtual IList<BasePivotField> PivotTableFields { get; set; }
}
我使用Fluent NHibernate映射,映射类在
之下public class PivotTableControlMap : SubclassMap<PivotTableControl>
{
public PivotTableControlMap()
{
References(x => x.Criteria).Cascade.All().Column("PivotTableCriteria");
Map(x => x.Height);
Component(x => x.PagingProperties);
HasMany(x => x.PivotTableFields)
.KeyColumn("PivotTableId")
.Cascade.AllDeleteOrphan()
.AsBag();
}
}
public class PivotTableFieldMap : ClassMap<BasePivotField>
{
public PivotTableFieldMap()
{
Table("PivotTableField");
Id(x => x.SystemId);
Version(x => x.Version);
Map(x => x.FieldName);
References(x => x.Field).Cascade.All().Column("FieldId");
Map(x => x.FieldValuePrefix);
DiscriminateSubClassesOnColumn("PivotFieldType");
}
}
public class PivotColumnFieldMap : SubclassMap<PivotColumnField>
{
public PivotColumnFieldMap()
{
Component(x => x.FieldCriteria).ColumnPrefix("PivotTable");
Map(x => x.Width);
}
}
还有其他类从BasePivotField继承,但为了简洁,我将它们遗漏了。
问题是当我使用NHibernate从数据库加载数据透视表控件时,PivotTableFields集合不会被加载。 抛出的异常说“创建代理实例失败”。深入研究异常,我可以看到PivotTableFields说“非法访问加载集合”。 我可以确认会议没有结束。如果我不使用延迟加载,问题仍然存在。
我在其他地方使用了类似的模型和映射,它们工作正常。我在这做错了什么? 任何线索都将受到高度赞赏!
答案 0 :(得分:0)
我不确定它是否解决了这个问题,但无论如何你需要在PivotColumnFieldMap中添加DiscriminatorValue(x =&gt; x.FieldType)