Исключение, когда вызов содержится в отражении - PullRequest
1 голос
/ 29 июня 2019

Я передаю некоторые параметры (propertyName и arrayIds) в свой сервис и строю дерево выражений с помощью отражения.Когда я использую Entity Framework все в порядке.Несколько дней назад я выполняю миграцию на EF Core и получаю сообщение об ошибке (Data is Null. Этот метод или свойство нельзя вызывать для значений Null.)

public static IQueryable Where(this IQueryable source, string propertyName,IEnumerable searchValues)
{
            //Get target's T 
var targetType = source.GetType().GetGenericArguments().FirstOrDefault();
    if (targetType == null)
                throw new ArgumentException("Should be IEnumerable<T>", "target");

            //Get searchValues's T
            Type searchValuesType;
            if (searchValues.GetType().IsArray)
                searchValuesType = searchValues.GetType().GetElementType();
            else
                searchValuesType = searchValues.GetType().GetGenericArguments().FirstOrDefault();

            if (searchValuesType == null)
               throw new ArgumentException("Should be IEnumerable<T>", "searchValues");

            //Create a p parameter with the type T of the items in the -> target IEnumerable<T>
            var containsLambdaParameter = Expression.Parameter(targetType, "i");

            //Create a property accessor using the property name -> p.#propertyName#
            var property = Expression.Property(containsLambdaParameter, targetType, propertyName);

            //Create a constant with the -> IEnumerable<T> searchValues
            var searchValuesAsConstant = Expression.Constant(searchValues/*, searchValues.GetType()*/);

            var res = Expression.Convert(property, searchValuesType);

            //Create a method call -> searchValues.Contains(p.Id)
            var containsBody = Expression.Call(typeof(Enumerable), "Contains", new[] { searchValuesType }, searchValuesAsConstant, res);

            //Create a lambda expression with the parameter p -> p => searchValues.Contains(p.Id)
            var containsLambda = Expression.Lambda(containsBody, containsLambdaParameter);

            return source.Provider.CreateQuery(
                Expression.Call(
                    typeof(Queryable), "Where",
                    new Type[] { source.ElementType },
                    source.Expression, containsLambda));

        }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...