分享一个 EF6 分页查询数据的 IQueryable 扩展方法

7 篇文章 0 订阅

image

前言

不废话,直接上方法。_

IQueryable 扩展方法

  1. 方法一

    /// <summary>
    /// 由其它 Reponsitory 提供数据源,分页查询数据
    /// </summary>
    /// <typeparam name="T"></typeparam>
    /// <typeparam name="S"></typeparam>
    /// <param name="source"></param>
    /// <param name="pageIndex"></param>
    /// <param name="pageSize"></param>
    /// <param name="whereLambda"></param>
    /// <param name="orderbyLambda"></param>
    /// <param name="total"></param>
    /// <param name="isAsc"></param>
    /// <returns></returns>
    public static List<T> FindPageList<T, S>(this IQueryable<T> source, int pageIndex, int pageSize, Expression<Func<T, bool>> whereLambda, Expression<Func<T, S>> orderbyLambda, out int total, bool isAsc)
    {
    	total = source.Where(whereLambda).Count();
    
    	List<T> result;
    	if (isAsc)
    	{
    		result = source
    		  .Where(whereLambda)
    		  .OrderBy(orderbyLambda)
    		  .Skip(pageSize * (pageIndex - 1))
    		  .Take(pageSize)
    		  .ToList();
    	}
    	else
    	{
    		result = source
    		 .Where(whereLambda)
    		 .OrderByDescending(orderbyLambda)
    		 .Skip(pageSize * (pageIndex - 1))
    		 .Take(pageSize)
    		 .ToList();
    	}
    	return result;
    }
    
  2. 方法一

    /// <summary>
    /// 使用动态拼接 OrderBy 语句,分页查询数据
    /// </summary>
    /// <typeparam name="T"></typeparam>
    /// <param name="source"></param>
    /// <param name="pageIndex"></param>
    /// <param name="pageSize"></param>
    /// <param name="whereLambda"></param>
    /// <param name="orderbyExpression"></param>
    /// <param name="total"></param>
    /// <returns></returns>
    public static List<T> FindPageList<T>(this IQueryable<T> source, int pageIndex, int pageSize, Expression<Func<T, bool>> whereLambda, string orderbyExpression, out int total)
    {
    	total = source.Where(whereLambda).Count();
    
    	var result = source
    		.Where(whereLambda)
    		.OrderBy(orderbyExpression)
    		.Skip(pageSize * (pageIndex - 1))
    		.Take(pageSize)
    		.ToList();
    
    	return result;
    }
    
  3. 方法说明

    • 方法一使用 EF 传统的排序方法,所以不得不根据升序或降序的需求分开来写,代码有点复杂和重复

    • 方法二利用前文所介绍的 System.Linq.Dynamic 技术,代码更加简洁可读,但性能比方法一稍微差些

    • 这两个扩展方法的思路是利用 IQueryable 的不会立即执行的特点,将具体业务数据查询跟分页展示数据解耦,提高代码的复用性和可维护性。

使用例子

  1. 方法一的使用例子

    public List<T> QueryPageList<S>(int pageIndex, int pageSize, Expression<Func<T, bool>> whereLambda, Expression<Func<T, S>> orderbyLambda, out int total, bool isAsc)
    {
    	var source = _dbContext.Set<T>().AsNoTracking().AsQueryable();
    	var result = source.FindPageList(pageIndex, pageSize, whereLambda, orderbyLambda, out total, isAsc);
    	return result; 
    }
    
    public List<TB01Dto> QueryPageList(QueryPageParams queryPageParams, out int total)
    {
    	Expression<Func<TB01, bool>> whereLambda = a => !a.STSHT01.Equals("D", StringComparison.OrdinalIgnoreCase);
    	if (!string.IsNullOrEmpty(queryPageParams.SearchKeyword))
    	{
    		Expression<Func<TB01, bool>> second = (a => a.NAMEHT01.Contains(queryPageParams.SearchKeyword) || a.COMPHT01 == queryPageParams.SearchKeyword);
    		whereLambda = whereLambda.And(second);
    	}
    	var list = QueryPageList(queryPageParams.PageIndex, queryPageParams.PageSize, whereLambda, (a => a.COMPHT01), out total, queryPageParams.IsAsc);
    	var result = CommonUtil.TranObject2OtherType<List<TB01Dto>>(list);
    	return result;
    }
    
  2. 方法二的使用例子

    public List<UserMenuDTO> QueryPageList(QueryPageParamsForuserMenu queryPageParams, out int total)
    {
    	 var query = userMenuReposition.QueryMenuUsers(queryPageParams.MenuUserName);
    	 
    	 Expression<Func<UserMenuDTO, bool>> whereLambda = a => true;
    	 
    	 if (queryPageParams.CompanyCodes != null && queryPageParams.CompanyCodes.Length > 0)
    	 {
    		Expression<Func<UserMenuDTO, bool>> second = (a => queryPageParams.CompanyCodes.Contains(a.COMPHT03));
    		whereLambda = whereLambda.And(second); 
    	 }
    	 
    	 var list = query.FindPageList(queryPageParams.PageIndex, queryPageParams.PageSize, whereLambda, "COMPHT03, MNUCDHT03", out total);
    	 
    	 return list;
    }
    

总结

分页查询数据是在处理大量数据时常用的一种技术,对于提高系统性能,优化用户体验,节约资源,并保证系统的稳定性和安全性等方面,非常有用。本文利用 IQueryable 不会立即执行的特点,扩展了 IQueryable 的方法,将具体业务数据查询跟分页展示数据解耦,有一定的适用性,可以将代码直接拷贝到项目中使用。

往期精彩

  1. 不会使用 EF Core 的 Code First 模式?来看看这篇文章,手把手地教你
  2. EF Core 性能很差?试试这 6 个小技巧
  3. 如何在 EF Core 中使用乐观并发控制
  4. EF Core 在实际开发中,如何分层?

我是老杨,一个奋斗在一线的资深研发老鸟,让我们一起聊聊技术,聊聊程序人生,共同学习,共同进步

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯智能台灯

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值