我的数据模型看起来像这样。
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 从数据库加载 PivotTableControls 时,不会加载 PivotTableFields 集合。抛出的异常说“创建代理实例失败”。深入研究异常,我可以看到 PivotTableFields 说“非法访问加载集合”。我可以确认会话没有关闭。如果我不使用延迟加载,问题仍然存在。
我在其他地方使用过类似的模型和映射,它们工作正常。我在这里做错了什么?任何线索将不胜感激!