每个子类继承策略使用NHibernate表时使用Casting代理的问题

nab*_*rid 11 nhibernate lazy-loading nhibernate-mapping fluent-nhibernate

我有一个抽象的基类并继承了poco实体.我使用表每子类继承与流畅的nhibernate 1.1自动化.

类继承如下所示

节点(抽象类)放置:节点资产:节点

Node类基本上是树结构.

 public abstract class Node 
    {
        public virtual int Id
        {
            get;
            set;
        }

        public virtual Node ParentNode
        {
            get;
            set;
        }

        public virtual ICollection<Node> ChildNodes
        {
            get;
            set;
        }
}
Run Code Online (Sandbox Code Playgroud)

现在的问题是,当我从数据库获取Asset的对象并执行objAsset.ParentNode时,我可以将ParentNode强制转换为Asset或Place,但是如果我执行类似objAsset.ParentNode.ParentNode.ParentNode的操作,那么ParentNode将显示为类型" {Castle.Proxies.NodeProxy}"我无法将其投射到Place或Asset.

我知道在我的情况下,最终结果应该是Place类型,因为记录存在于Place表的数据库中但由于某种原因NHibernate不能将它延迟加载到实际的派生类型,它只能转换为基类Node .

任何的想法?

等待Nabeel

Die*_*hon 15

Oren在这里对此进行了很好的解释:http://ayende.com/Blog/archive/2009/09/03/answer-the-lazy-loaded-inheritance-many-to-one-association-orm.aspx

简而言之,代理继承自关联的类型,而不是继承的类型,因为在转到DB之前不知道(并且您无法更改对象的类型)

更新:可能的解决方法是在Node中泄漏对实际对象的引用:

public virtual Node Self { get { return this; } }
Run Code Online (Sandbox Code Playgroud)

这将为您提供基础资产或地点.小心一点.

  • 另外,如文章所述; 一个解决方案是禁用关联上的延迟加载,这将为您提供实际对象. (3认同)