LINQ 通过动态生成lambda表达式,实现根据指定属性名称对序列进行排序

目前,对于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 = Expression.Parameter(typeof(TSource), "c");
            PropertyInfo pi = typeof(TSource).GetProperty(property);
            MemberExpression selector = Expression.MakeMemberAccess(param, pi);
            LambdaExpression le = Expression.Lambda(selector, param);
            string methodName = (descending) ? "OrderByDescending" : "OrderBy";
            MethodCallExpression resultExp = Expression.Call(typeof(Queryable), methodName, new Type[] { typeof(TSource), pi.PropertyType }, source.Expression, le);
            return source.Provider.CreateQuery<TSource>(resultExp);
        }

调用如下:

            using (Entities entitys = new Entities())
            {
                var lists = Kits.OrderBy(entitys.Members.Where(n => true), "MemberId", true).ToList();                
            }


执行结果如下:



当然,你也可以加多点查询条件,只要稍微修改下就可以了




其他参考:使用Expression动态创建lambda表达式 

                    http://bbs.csdn.net/topics/390773344

                    Expression.Call 方法 (Type, String, Type[], Expression[])

                    IQueryProvider.CreateQuery 方法 (Expression)

                    http://www.cnblogs.com/126/archive/2007/09/09/887723.html
   




    
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值