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)
这将为您提供基础资产或地点.小心一点.
归档时间: |
|
查看次数: |
5201 次 |
最近记录: |