我有3类:人,Employee1,和Employee2LINQ如何通过加入NHibernate和独立那里查询
public class Employee1 : Person
{
}
public class Employee2 : Person
{
}
我需要在Person_Table的查询一段时间内需要加入Employee1_Table或Employee_Table。
var q = SessionInstance.Query<Person>();
if (dto.Code != null) // A1 Condition
q = q.Where(x => x.Code == dto.Code);
//if(A2 Condition)
//if(A3 Condition)
//...
switch (dto.Type)
{
case PersonType.Employee1:
var q1 = SessionInstance.Query<Employee1>();
q.Join(q1, x => x.Id, xx => xx.Id, (x, xx) => x);
if (!String.IsNullOrEmpty(dto.Unit)) // B1 Condition
q1 = q1.Where(xx => xx.Unit == dto.Unit);
//if(B2 Condition)
//if(B3 Condition)
//...
return q1.ToList<Person>();
case PersonType.Employee2:
var q2 = SessionInstance.Query<Employee2>();
q.Join(q2, x => x.Id, xx => xx.Id, (x, xx) => x);
if (!String.IsNullOrEmpty(dto.Serial)) // C1 Condition
q2 = q2.Where(xx => xx.Serial == dto.Serial);
//if(C2 Condition)
//if(C3 Condition)
//...
return q2.ToList<Person>();
default:
return q.ToList();
}
此连接查询不完整。如果dto.Type等于PersonType.Employee1或PersonType.Employee2,A1 , A2 , ...
不会影响。但是对于默认情况下的开关A1 , A2 , ...
对查询有影响。 我在哪里条件在3个单独的类是很多,我需要单独添加Where
条件的查询。为什么?
UPDATE:
var q = SessionInstance.Query<Person>();
if (dto.Code != null) // A1 Condition
q = q.Where(x => x.Code == dto.Code);
//if(A2 Condition)
//if(A3 Condition)
//...
var q1 = SessionInstance.Query<Employee1>();
if (!String.IsNullOrEmpty(dto.Unit)) // B1 Condition
q1 = q1.Where(xx => xx.Unit == dto.Unit);
//if(B2 Condition)
//if(B3 Condition)
//...
return q.Join(q1, x => x.Id, xx => xx.Id, (x, xx) => x).ToList<Person>();
此更新的查询有异常,如果B1
条件为真。此例外的消息是:不支持指定的方法。
堆栈跟踪是:
at NHibernate.Hql.Ast.ANTLR.PolymorphicQuerySourceDetector.GetClassName(IASTNode querySource)
at NHibernate.Hql.Ast.ANTLR.PolymorphicQuerySourceDetector.Process(IASTNode tree)
at NHibernate.Hql.Ast.ANTLR.AstPolymorphicProcessor.Process()
at NHibernate.Hql.Ast.ANTLR.ASTQueryTranslatorFactory.CreateQueryTranslators(IASTNode ast, String queryIdentifier, String collectionRole, Boolean shallow, IDictionary`2 filters, ISessionFactoryImplementor factory)
at NHibernate.Hql.Ast.ANTLR.ASTQueryTranslatorFactory.CreateQueryTranslators(String queryIdentifier, IQueryExpression queryExpression, String collectionRole, Boolean shallow, IDictionary`2 filters, ISessionFactoryImplementor factory)
at NHibernate.Engine.Query.QueryPlanCache.GetHQLQueryPlan(IQueryExpression queryExpression, Boolean shallow, IDictionary`2 enabledFilters)
at NHibernate.Impl.AbstractSessionImpl.GetHQLQueryPlan(IQueryExpression queryExpression, Boolean shallow)
at NHibernate.Impl.AbstractSessionImpl.CreateQuery(IQueryExpression queryExpression)
at NHibernate.Linq.NhQueryProvider.PrepareQuery(Expression expression, IQuery& query, NhLinqExpression& nhQuery)
at NHibernate.Linq.NhQueryProvider.Execute[TResult](Expression expression)
at Remotion.Data.Linq.QueryableBase`1.GetEnumerator()
at System.Collections.Generic.List`1..ctor(IEnumerable`1 collection)
at System.Linq.Enumerable.ToList[TSource](IEnumerable`1 source)
@Berggren所以我该怎么做? – Ehsan
编辑与如何着手的建议。 –
我在q.Join()之前移动q1.Where(),并返回q.ToList()而不是q1.ToList()。现在q.Where()对查询有影响,但q1不影响。此外,我更改q.Join()q = q.Join(),如果dto.Unit等于null仍然q1.Where不会影响,如果dto.Unit有值,此代码有一个例外,此消息'指定的方法是不支持。' – Ehsan