代码之家  ›  专栏  ›  技术社区  ›  Craig

亚麻酸盐

  •  5
  • Craig  · 技术社区  · 15 年前

    我正在使用旧的linq提供者nHibernate并耐心等待 让新的出来。我相信它会帮我省下很多痛苦。 引用未设置为对象的实例”。线路 问题是。使用这样的语句有什么已知的问题吗 林克?

    var agencies = m_AgencyRepository.Linq;
    
    Discipline[] disciplines = user.Disciplines.ToArray<Discipline>();
    
    return (from c in agencies
                       where (String.IsNullOrEmpty(criteria.AgencyName) || c.AgencyName.Contains(criteria.AgencyName))
                        && (criteria.AgencyType == null || c.AgencyType.AgencyTypeId == criteria.AgencyType)
                        && (String.IsNullOrEmpty(criteria.AgencyLevel) || c.AgencyLevel.AgencyLevelId == criteria.AgencyLevel)
                        && (c.Disciplines.Any(d => disciplines.Contains(d)))
    select c)
    

    堆栈跟踪:

       at NHibernate.Loader.Criteria.CriteriaQueryTranslator.GetEntityName(ICriteria subcriteria, String propertyName)
       at NHibernate.Loader.Criteria.CriteriaQueryTranslator.GetType(ICriteria subcriteria, String propertyName)
       at NHibernate.Loader.Criteria.CriteriaQueryTranslator.GetTypeUsingProjection(ICriteria subcriteria, String propertyName)
       at NHibernate.Criterion.InExpression.GetTypedValues(ICriteria criteria, ICriteriaQuery criteriaQuery)
       at NHibernate.Criterion.Junction.GetTypedValues(ICriteria criteria, ICriteriaQuery criteriaQuery)
       at NHibernate.Loader.Criteria.CriteriaQueryTranslator.GetQueryParameters()
       at NHibernate.Criterion.SubqueryExpression.InitializeInnerQueryAndParameters(ICriteriaQuery criteriaQuery)
       at NHibernate.Criterion.SubqueryExpression.ToSqlString(ICriteria criteria, ICriteriaQuery criteriaQuery, IDictionary`2 enabledFilters)
       at NHibernate.Criterion.Junction.ToSqlString(ICriteria criteria, ICriteriaQuery criteriaQuery, IDictionary`2 enabledFilters)
       at NHibernate.Loader.Criteria.CriteriaQueryTranslator.GetWhereCondition(IDictionary`2 enabledFilters)
       at NHibernate.Loader.Criteria.CriteriaJoinWalker..ctor(IOuterJoinLoadable persister, CriteriaQueryTranslator translator, ISessionFactoryImplementor factory, CriteriaImpl criteria, String rootEntityName, IDictionary`2 enabledFilters)
       at NHibernate.Loader.Criteria.CriteriaLoader..ctor(IOuterJoinLoadable persister, ISessionFactoryImplementor factory, CriteriaImpl rootCriteria, String rootEntityName, IDictionary`2 enabledFilters)
       at NHibernate.Impl.SessionImpl.List(CriteriaImpl criteria, IList results)
       at NHibernate.Impl.CriteriaImpl.List(IList results)
       at NHibernate.Impl.CriteriaImpl.List()
       at NHibernate.Impl.CriteriaImpl.UniqueResult()
       at NHibernate.Linq.Visitors.ImmediateResultsVisitor`1.HandleAggregateCall(MethodCallExpression call)
       at NHibernate.Linq.Visitors.ImmediateResultsVisitor`1.VisitMethodCall(MethodCallExpression call)
       at NHibernate.Linq.Visitors.ExpressionVisitor.Visit(Expression exp)
       at NHibernate.Linq.Visitors.NHibernateExpressionVisitor.Visit(Expression exp)
       at NHibernate.Linq.Visitors.ImmediateResultsVisitor`1.GetResults(MethodCallExpression expr)
       at NHibernate.Linq.Visitors.RootVisitor.HandleImmediateResultsCall(MethodCallExpression call)
       at NHibernate.Linq.Visitors.RootVisitor.VisitMethodCall(MethodCallExpression expr)
       at NHibernate.Linq.Visitors.ExpressionVisitor.Visit(Expression exp)
       at NHibernate.Linq.Visitors.NHibernateExpressionVisitor.Visit(Expression exp)
       at NHibernate.Linq.Visitors.NHibernateQueryTranslator.Translate(Expression expression, QueryOptions queryOptions)
       at NHibernate.Linq.NHibernateQueryProvider.Execute(Expression expression)
       at NHibernate.Linq.QueryProvider.System.Linq.IQueryProvider.Execute[T](Expression expression)
       at System.Linq.Queryable.Count[TSource](IQueryable`1 source)
       at PPSS.Services.AgencyRepository.List(AgencyListCriteria criteria, Int32& total) in C:\Development\PPSS\PPSS.Services\Services\Agency\AgencyRepository.cs:line 57
       at PPSS.Models.AgencyViewData..ctor(AgencyListCriteria criteria) in C:\Development\PPSS\PPSS\Domains\Maintenance\ViewModels\AgencyViewData.cs:line 26
       at PPSS.Controllers.AgencyController.Index(AgencyListCriteria criteria) in C:\Development\PPSS\PPSS\Domains\Maintenance\Controllers\AgencyController.cs:line 34
       at lambda_method(ExecutionScope , ControllerBase , Object[] )
       at System.Web.Mvc.ActionMethodDispatcher.Execute(ControllerBase controller, Object[] parameters)
       at System.Web.Mvc.ReflectedActionDescriptor.Execute(ControllerContext controllerContext, IDictionary`2 parameters)
       at System.Web.Mvc.ControllerActionInvoker.InvokeActionMethod(ControllerContext controllerContext, ActionDescriptor actionDescriptor, IDictionary`2 parameters)
       at System.Web.Mvc.ControllerActionInvoker.<>c__DisplayClassa.<InvokeActionMethodWithFilters>b__7()
       at System.Web.Mvc.ControllerActionInvoker.InvokeActionMethodFilter(IActionFilter filter, ActionExecutingContext preContext, Func`1 continuation)
    
    2 回复  |  直到 15 年前
        1
  •  5
  •   Bryan Watts    15 年前

    改变

    user.Disciplines.ToArray<Discipline>()
    

    user.Disciplines.ToList<Discipline>()
    

    .Contains() 对混凝土的要求 List 物体。

        2
  •  1
  •   tvanfosson    15 年前

    disciplines 是非空的,但您也可以检查它。

     (c.Disciplines != null
        && c.Disciplines.Any(d => disciplines != null
                                   && disciplines.Contains(d)))