У меня есть список объектов, имеющих отношения, по которым я хочу получить все те, у которых их нет (поэтому те, которые не используются).
Сначала я получаю все свойства, которые являются коллекциями, а затем использую этотв предложении Where
:
List<System.Reflection.PropertyInfo> collectionsProperties =
typeof(DAL.Entities.File).GetProperties()
.Where(p => p.PropertyType.IsGenericType &&
p.PropertyType.GetGenericTypeDefinition() == typeof(ICollection<>))
.ToList<System.Reflection.PropertyInfo>();
var files = await _context.Files
.Where(f => collectionsProperties.Where(p => (p.GetValue(f) as System.Collections.IEnumerable).Cast<object>().Count() != 0).Count() == 0)
.ToListAsync();
я получаю ArgumentException
, и я не нашел подсказки, почему я это получаю.Я проверил свое предложение where, получая два объекта (один не используется, один да), и он работает правильно.
var fileUsed = await _context.Files.Include(i => i.FileClips).FirstOrDefaultAsync(f => f.Id == 29870);
var fileNotUsed = _context.Files.Include(i => i.DirectoryFloors).Where(f => f.Id == 37949).First();
var isFileNotUsed1 = collectionsProperties.Where(p => (p.GetValue(fileUsed) as System.Collections.IEnumerable).Cast<object>().Count() != 0).Count() == 0;
var isFileNotUsed2 = collectionsProperties.Where(p => (p.GetValue(fileNotUsed) as System.Collections.IEnumerable).Cast<object>().Count() != 0).Count() == 0;
Это дает мне isFileNotUsed1
false и второе значение true, чего я и ожидаю.
Имеет ли кто-либо из вас опыт использования пункта «Отражение в месте»?
РЕДАКТИРОВАТЬ-1: полное исключение
e.Source = "Microsoft.EntityFrameworkCore"
e.HResult = -2147024809
System.ArgumentException: La valeur n'est pas comprise dans la plage attendue.
à System.SharedTypeExtensions.GetSequenceType(Type type)
à Microsoft.EntityFrameworkCore.Query.EntityQueryModelVisitor.VisitMainFromClause(MainFromClause fromClause, QueryModel queryModel)
à Remotion.Linq.Clauses.MainFromClause.Accept(IQueryModelVisitor visitor, QueryModel queryModel)
à Remotion.Linq.QueryModelVisitorBase.VisitQueryModel(QueryModel queryModel)
à Microsoft.EntityFrameworkCore.Query.EntityQueryModelVisitor.VisitQueryModel(QueryModel queryModel)
à Microsoft.EntityFrameworkCore.Query.RelationalQueryModelVisitor.VisitQueryModel(QueryModel queryModel)
à Microsoft.EntityFrameworkCore.Query.ExpressionVisitors.RelationalEntityQueryableExpressionVisitor.VisitSubQuery(SubQueryExpression expression)
à Remotion.Linq.Clauses.Expressions.SubQueryExpression.Accept(ExpressionVisitor visitor)
à System.Linq.Expressions.ExpressionVisitor.Visit(Expression node)
à System.Linq.Expressions.ExpressionVisitor.VisitBinary(BinaryExpression node)
à System.Linq.Expressions.BinaryExpression.Accept(ExpressionVisitor visitor)
à System.Linq.Expressions.ExpressionVisitor.Visit(Expression node)
à Microsoft.EntityFrameworkCore.Query.EntityQueryModelVisitor.ReplaceClauseReferences(Expression expression, IQuerySource querySource, Boolean inProjection)
à Microsoft.EntityFrameworkCore.Query.EntityQueryModelVisitor.VisitWhereClause(WhereClause whereClause, QueryModel queryModel, Int32 index)
à Microsoft.EntityFrameworkCore.Query.RelationalQueryModelVisitor.VisitWhereClause(WhereClause whereClause, QueryModel queryModel, Int32 index)
à Remotion.Linq.Clauses.WhereClause.Accept(IQueryModelVisitor visitor, QueryModel queryModel, Int32 index)
à Remotion.Linq.QueryModelVisitorBase.VisitBodyClauses(ObservableCollection`1 bodyClauses, QueryModel queryModel)
à Remotion.Linq.QueryModelVisitorBase.VisitQueryModel(QueryModel queryModel)
à Microsoft.EntityFrameworkCore.Query.EntityQueryModelVisitor.VisitQueryModel(QueryModel queryModel)
à Microsoft.EntityFrameworkCore.Query.RelationalQueryModelVisitor.VisitQueryModel(QueryModel queryModel)
à Microsoft.EntityFrameworkCore.Query.ExpressionVisitors.RelationalEntityQueryableExpressionVisitor.VisitSubQuery(SubQueryExpression expression)
à Remotion.Linq.Clauses.Expressions.SubQueryExpression.Accept(ExpressionVisitor visitor)
à System.Linq.Expressions.ExpressionVisitor.Visit(Expression node)
à System.Linq.Expressions.ExpressionVisitor.VisitBinary(BinaryExpression node)
à System.Linq.Expressions.BinaryExpression.Accept(ExpressionVisitor visitor)
à System.Linq.Expressions.ExpressionVisitor.Visit(Expression node)
à Microsoft.EntityFrameworkCore.Query.EntityQueryModelVisitor.ReplaceClauseReferences(Expression expression, IQuerySource querySource, Boolean inProjection)
à Microsoft.EntityFrameworkCore.Query.EntityQueryModelVisitor.VisitWhereClause(WhereClause whereClause, QueryModel queryModel, Int32 index)
à Microsoft.EntityFrameworkCore.Query.RelationalQueryModelVisitor.VisitWhereClause(WhereClause whereClause, QueryModel queryModel, Int32 index)
à Remotion.Linq.Clauses.WhereClause.Accept(IQueryModelVisitor visitor, QueryModel queryModel, Int32 index)
à Remotion.Linq.QueryModelVisitorBase.VisitBodyClauses(ObservableCollection`1 bodyClauses, QueryModel queryModel)
à Remotion.Linq.QueryModelVisitorBase.VisitQueryModel(QueryModel queryModel)
à Microsoft.EntityFrameworkCore.Query.EntityQueryModelVisitor.VisitQueryModel(QueryModel queryModel)
à Microsoft.EntityFrameworkCore.Query.RelationalQueryModelVisitor.VisitQueryModel(QueryModel queryModel)
à Microsoft.EntityFrameworkCore.Query.EntityQueryModelVisitor.CreateAsyncQueryExecutor[TResult](QueryModel queryModel)
à Microsoft.EntityFrameworkCore.Storage.Database.CompileAsyncQuery[TResult](QueryModel queryModel)
à Microsoft.EntityFrameworkCore.Query.Internal.QueryCompiler.CompileAsyncQueryCore[TResult](Expression query, IQueryModelGenerator queryModelGenerator, IDatabase database)
à Microsoft.EntityFrameworkCore.Query.Internal.QueryCompiler.<>c__DisplayClass22_0`1.<CompileAsyncQuery>b__0()
à Microsoft.EntityFrameworkCore.Query.Internal.CompiledQueryCache.GetOrAddQueryCore[TFunc](Object cacheKey, Func`1 compiler)
à Microsoft.EntityFrameworkCore.Query.Internal.CompiledQueryCache.GetOrAddAsyncQuery[TResult](Object cacheKey, Func`1 compiler)
à Microsoft.EntityFrameworkCore.Query.Internal.QueryCompiler.CompileAsyncQuery[TResult](Expression query)
à Microsoft.EntityFrameworkCore.Query.Internal.QueryCompiler.ExecuteAsync[TResult](Expression query)
à Microsoft.EntityFrameworkCore.Query.Internal.EntityQueryProvider.ExecuteAsync[TResult](Expression expression)
à Microsoft.EntityFrameworkCore.Query.Internal.EntityQueryable`1.System.Collections.Generic.IAsyncEnumerable<TResult>.GetEnumerator()
à System.Linq.AsyncEnumerable.<Aggregate_>d__6`3.MoveNext()
--- Fin de la trace de la pile à partir de l'emplacement précédent au niveau duquel l'exception a été levée ---
à System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
à System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
à System.Runtime.CompilerServices.TaskAwaiter`1.GetResult()
à Itesmedia.ItesLive.BusinessLayer.Files.FilesServices.<GetFilesUnusedAsync>d__3.MoveNext()
--- Fin de la trace de la pile à partir de l'emplacement précédent au niveau duquel l'exception a été levée ---
à System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
à System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
à System.Runtime.CompilerServices.TaskAwaiter`1.GetResult()
à Itesmedia.ItesLive.Iclient.Core.Jobs.CleanUselessFiles.<_Execute>d__0.MoveNext()