微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

.Net Core 3.1 Web Api 中的规范模式

如何解决.Net Core 3.1 Web Api 中的规范模式

我对搜索方法使用规范查询,它包括搜索、orderBy、groupBy。 Search 和 Orderby 没问题,但我在这一行的 groupBy 方法中遇到问题 query.GroupBy(spec.GroupBy).SelectMany(x => x)

请查看以下代码

 public async Task<PaginatedResult<List<EmployeeTypeResponse>>> Handle(GetAllEmployeeTypesQuery request,CancellationToken cancellationToken)
        {

            var employeeTypesWithPaging = _employeeTypeRepository.FindWithSpecificationPattern(new Employeetypespecifcation(request.Filter,true),true);

我想在 ApplyGroupBy(x => x.ShopId); 处使用 ShopId 申请 groupBy;

   public class Employeetypespecifcation : BaseSpecifcation<EmployeeType>
   {
    public Employeetypespecifcation()
    {

    }
    public Employeetypespecifcation(PaginationFilter Filter,bool isPaging)
    {

        if (!string.IsNullOrEmpty(Filter.GroupBy))
        {
            ApplyGroupBy(x => x.ShopId);
        }

        var predicate = PredicateBuilder.True<EmployeeType>();

        if (!string.IsNullOrEmpty(Filter.SearchText))
        {
            predicate = predicate.And(x => x.Name.Contains(Filter.SearchText) || x.Code.Contains(Filter.SearchText));
        }

        if (Filter.ShopId != null)
        {
            predicate = predicate.And(c => c.ShopId == Filter.ShopId);
        }

    }
}

像这样的 BaseSpecifcation 类

 public class BaseSpecifcation<T> : ISpecification<T>
{
    public BaseSpecifcation()
    {
    }
    public BaseSpecifcation(Expression<Func<T,bool>> criteria)
    {
        Criteria = criteria;
    }

    public Expression<Func<T,object>> OrderBy { get; private set; }
    public Expression<Func<T,object>> OrderByDescending { get; private set; }
    public Expression<Func<T,object>> GroupBy { get; private set; }

    protected virtual void ApplyGroupBy(Expression<Func<T,object>> groupByExpression)
    {
        GroupBy = groupByExpression;
    }
    protected void AddOrderBy(Expression<Func<T,object>> orderByExpression)
    {
        OrderBy = orderByExpression;
    }
    protected void AddOrderByDescending(Expression<Func<T,object>> orderByDescExpression)
    {
        OrderByDescending = orderByDescExpression;
    }
    
}

FindWithSpecificationPattern 和 GetQuery 方法

 public IEnumerable<T> FindWithSpecificationPattern(ISpecification<T> specification = null,bool isPaging = false)
    {         
        return  SpecificationEvaluator<T>.GetQuery(DbContext.Set<T>().AsQueryable(),specification,isPaging);
    }

   public class SpecificationEvaluator<TEntity> where TEntity : class
{
    public static IQueryable<TEntity> GetQuery(IQueryable<TEntity> inputQuery,ISpecification<TEntity> spec,bool isPaging)
    {
        var query = inputQuery;

        if (spec.Criteria != null)
        {
            query = query.Where(spec.Criteria);
        }

        if (spec.GroupBy != null)
        {
            query = query.GroupBy(spec.GroupBy).SelectMany(x => x);
        }
    }
}

在这条线上遇到了问题

query = query.GroupBy(spec.GroupBy).SelectMany(x => x);

虽然它不会抛出异常,但我无法得到结果。当我调试时,我看到错误消息

Query='((Microsoft.EntityFrameworkCore.Query.Internal.EntityQueryable)query).DebugView.Query' 引发了类型为“system.invalidOperationException”的异常>

我在 Google 中搜索了很多次,但没有看到任何使用规范模式实现 GroupBy 的示例。 请帮帮我,非常感谢!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?