QueryableHelper

复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
using System.Reflection;
using System.Text;

namespace Oyang.Tool
{
    public class QueryableHelper
    {
        public static IQueryable<TSource> WhereIf<TSource>(IQueryable<TSource> source, bool isTrue, Expression<Func<TSource, bool>> predicate)
        {
            if (isTrue)
            {
                source = source.Provider.CreateQuery<TSource>(
                Expression.Call(
                    null,
                    Where_TSource_2(typeof(TSource)),
                    source.Expression, Expression.Quote(predicate)
                    ));
            }
            return source;
        }

        private static MethodInfo s_Where_TSource_2;

        private static MethodInfo Where_TSource_2(Type TSource) =>
             (s_Where_TSource_2 ??
             (s_Where_TSource_2 = new Func<IQueryable<object>, Expression<Func<object, bool>>, IQueryable<object>>(Queryable.Where).GetMethodInfo().GetGenericMethodDefinition()))
              .MakeGenericMethod(TSource);

        public static List<TSource> ToPageList<TSource>(IQueryable<TSource> source, ref int pageIndex, int pageSize, string sortField, bool isAsc, out int totalCount)
        {
            totalCount = source.Count();
            int pageCount = totalCount % pageSize == 0 ? totalCount / pageSize : totalCount / pageSize + 1;
            if (pageCount > 0 && pageIndex > pageCount)
            {
                pageIndex = pageCount;
            }

            var param = Expression.Parameter(typeof(TSource));
            var body = Expression.Property(param, sortField);
            dynamic keySelector = Expression.Lambda(body, param);
            source = isAsc ? Queryable.OrderBy(source, keySelector) : Queryable.OrderByDescending(source, keySelector);
            source = source.Skip((pageIndex - 1) * pageSize).Take(pageSize);
            return source.ToList();
        }

        public static List<TSource> ToPageList<TSource>(IQueryable<TSource> source, IPagination p)
        {
            int pageIndex = p.PageIndex;
            List<TSource> temp = ToPageList<TSource>(source, ref pageIndex, p.PageSize, p.SortField, p.IsAsc, out int totalCount);
            p.TotalCount = totalCount;
            p.PageIndex = pageIndex;
            return temp;
        }
    }
}
复制代码

 

posted @   欧阳.NET  阅读(382)  评论(1编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示