0

我正在使用带有流畅映射的 NHibernate。我有以下情况:

public class A
{
     public virtual int ID{get; set;}
     public virtual B BReference {get; set;}
     public virtual string aProperty {get; set;}
}

public class B
{
    public virtual int ID {get;set;}
    public virtual string Name {get; set;}
}

public class MapA: Map<A>
{
    Id(x=> x.ID);
    Map (x=> x.aProperty);
    References(x => x.BReference);
}

public class MapB : Map<B>
{
    Id(x=>x.ID);
    Map(x=>x.Name);
}

我想要做的是过滤属性 A.BReference.Name 上的 A 对象。我正在使用 queryover 进行查询:

public object GetResult(ISession session)
{
   var result = session.QueryOver<A>.Where(a=> a.BReference.Name=="Value").List();
   return result;
} 

目前 NHibernate 正在引发异常无法解析属性 BReference.Name of: A。

有没有办法克服这个问题?我现在无法更改查询模式,因为我们依赖它。谢谢你的帮助。

4

1 回答 1

1

嗨,您必须在编写条件之前使用 JoinAlias 加载相关表。

B bReference = null;
var result = session.QueryOver<A>()
.JoinAlias(x => x.BReference, () => bReference, NHibernate.SqlCommand.JoinType.LeftOuterJoin)
.Where(x => bReference.Name == "Value").List<A>();
于 2012-06-11T08:11:57.833 回答