Из-за Некоторая бизнес-логика, у нас есть сущность 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;
}
Подробнее здесь: https://stackoverflow.com/questions/786 ... r-grouping
Мобильная версия