Динамическая сортировка LINQ после группировкиC#

Место общения программистов C#
Ответить
Anonymous
 Динамическая сортировка LINQ после группировки

Сообщение Anonymous »

Мы написали общий фильтруемый репозиторий в .NET 8, который должен иметь возможность принимать список фильтров и список сортов и применять их к любому заданному объекту.
Из-за Некоторая бизнес-логика, у нас есть сущность Task, которую необходимо группировать каждый раз, когда она фильтруется. Группировка "съедает" сортировки, и они никогда не применяются, я проверил запрос, который выполняется. Но нам нужно выполнить сортировку после группировки, а затем применить нумерацию страниц.
Метод выглядит так:

Код: Выделить всё

public static (IQueryable Queryable, int TotalElements) BuildFilteredQuery(IQueryable queryable, List filters, List sorts, int pageNo, int pageSize, bool distinct)
{
queryable = ApplyFilters(queryable, filters);
queryable = ApplySorting(queryable, sorts);

if (distinct)
{
queryable = queryable.GroupBy("new(CountSort)").Select("it.First()");
}

var totalElements = queryable.Count();

if (pageSize != 0)
{
queryable = ApplyPaging(queryable, pageNo, pageSize);
}

return (queryable, totalElements);
}

private static IQueryable ApplySorting(IQueryable queryable, List sorts)
{
var sortingString = string.Join(", ", sorts.Select(s =>
$"{s.PropertyName} {(s.Direction == ListSortDirection.Ascending ? "asc" : "desc")}"));

if (!string.IsNullOrWhiteSpace(sortingString))
{
queryable = queryable.OrderBy(sortingString);
}

return queryable;
}
Если мы попытаемся применить сортировку после группировки, мы получим «Данный ключ 'EmptyProjectionMember' не присутствует в словаре».

Подробнее здесь: https://stackoverflow.com/questions/786 ... r-grouping
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»