0

我的数据模型看起来像这样。

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 说“非法访问加载集合”。我可以确认会话没有关闭。如果我不使用延迟加载,问题仍然存在。

我在其他地方使用过类似的模型和映射,它们工作正常。我在这里做错了什么?任何线索将不胜感激!

4

1 回答 1

0

我不确定它是否能解决问题,但无论如何您需要在 PivotColumnFieldMap 中添加 DiscriminatorValue(x => x.FieldType )

于 2012-09-05T10:33:02.217 回答