目前,对于Linq只是初步接触,还不熟悉,做项目的时候想到一个问题,如果想要查询任意字段的排序结果集,该怎么实现?
我们知道,T-SQL是非常容易解决这个问题,只要简单通过拼接T-SQL就可以达到该效果。
那么,Linq该怎么实现呢?
网上查了很多资料,找到一种办法就是通过自定义拓展方法方式实现,具体实现代码如下:
/// <summary>
/// 根据指定属性名称对序列进行排序
/// </summary>
/// <typeparam name="TSource">source中的元素的类型</typeparam>
/// <param name="source">一个要排序的值序列</param>
/// <param name="property">属性名称</param>
/// <param name="descending">是否降序</param>
/// <returns></returns>
public static IQueryable<TSource> OrderBy<TSource>(this IQueryable<TSource> source, string property, bool descending) where TSource : class
{
ParameterExpression param = (typeof(TSource), "c");
PropertyInfo pi = typeof(TSource).GetProperty(property);
MemberExpression selector = (param, pi);
LambdaExpression le = (selector, param);
string methodName = (descending) ? "OrderByDescending" : "OrderBy";
MethodCallExpression resultExp = (typeof(Queryable), methodName, new Type[] { typeof(TSource), }, , le);
return <TSource>(resultExp);
}
调用如下:
using (Entities entitys = new Entities())
{
var lists = ((n => true), "MemberId", true).ToList();
}
执行结果如下:
当然,你也可以加多点查询条件,只要稍微修改下就可以了
其他参考:使用Expression动态创建lambda表达式
/topics/390773344
方法 (Type, String, Type[], Expression[])
方法 (Expression)
/126/archive/2007/09/09/