Lambda动态排序分页通用方法
2024-09-29 12:08:02
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
using System.Text; namespace Common
{
public class QueryParameters
{
public QueryParameters(); public string order { get; set; }
public int page { get; set; }
public int rows { get; set; }
public string sort { get; set; }
} public class DataGrid<T>
{
/// <summary>
/// 默认构造函数
/// </summary>
public DataGrid() { } /// <summary>
/// 构造函数
/// </summary>
/// <param name="rows">表格数据</param>
public DataGrid(List<T> rows)
{
this.rows = rows;
}
private List<T> _rows = new List<T>(); /// <summary>
/// 表格数据
/// </summary>
public List<T> rows
{
get { return _rows; }
set
{
if (value != null)
{
_rows = value;
}
}
} /// <summary>
/// 总记录数
/// </summary>
public int total { get; set; } public static DataGrid<T> QueryWithParameters(IEnumerable<T> queryable, QueryParameters queryParameters)
{
if (queryable == null)
{
return new DataGrid<T>();
}
queryParameters = queryParameters ?? new QueryParameters();
IQueryable<T> source = Queryable.AsQueryable<T>(queryable); var page = queryParameters.page;
var rows = queryParameters.rows;
var sort = queryParameters.sort;
var order = queryParameters.order; int num = source.Count(); int count = (page - ) * rows; IQueryable<T> s = source; if (!string.IsNullOrWhiteSpace(sort))
{
var sortExpression = Expression.Parameter(source.ElementType);
var selector = Expression.Lambda(Expression.PropertyOrField(sortExpression, sort), sortExpression);
if (order.ToLower() == "asc")
{
s = (IQueryable<T>)source.Provider.CreateQuery(Expression.Call(typeof(Queryable), "OrderBy", new Type[] { source.ElementType, selector.Body.Type }, source.Expression, selector));
}
else if (order.ToLower() == "desc")
{
s = (IQueryable<T>)source.Provider.CreateQuery(Expression.Call(typeof(Queryable), "OrderByDescending", new Type[] { source.ElementType, selector.Body.Type }, source.Expression, selector));
}
} //方法1
s = count == ? s.Take(rows) : s.Skip(count).Take(rows);
//方法2
s = count == ? Queryable.Take<T>(s, rows) : Queryable.Take<T>(Queryable.Skip<T>(s, count), rows); return new DataGrid<T>()
{
total = num,
rows = s.ToList()
};
}
}
}
调用:
DataGrid<T>.QueryWithParameters(query, paging)
最新文章
- memcached安装及.NET中的Memcached.ClientLibrary使用详解
- Android事件分发机制浅谈(二)--源码分析(ViewGroup篇)
- Linux系统下输出某进程内存占用信息的c程序实现
- IIS使用Tip
- 站长、运维必备| 网站可用性监控产品 OneAPM Cloud Test 上线
- CPU/寄存器/内存
- [ReactJS] DOM Event Listeners in a React Component
- 轻量级IOC框架Guice
- Elasticsearch 快照和恢复
- Spring基础系列--AOP织入逻辑跟踪
- CodeForces - 833B The Bakery
- ToastUtils 工具类
- Entity Framework 问题集锦
- IDEA spirng boot @Autowired注解 mapper出现红色下划线解决方法
- R语言scale与unscale函数
- Spock集成入门
- Mac - MySQL初始密码忘记重置MySQL root密码
- CentOS7.5安装Tomcat8
- 一、vue:如何新建一个vue项目
- 分析java进程假死状况