日期:2014-05-20 浏览次数:21109 次
IEnumerable<TEntity> GetList<TEntity, TSortKey>(int count, Expression<Func<TEntity, TSortKey>> order, bool ascending);
using System; using System.Linq; using System.Linq.Expressions; using System.Reflection; namespace Name { public static class LinqSort { /// <summary> /// Linq动态排序 /// </summary> /// <typeparam name="T">T</typeparam> /// <param name="source">要排序的数据源</param> /// <param name="value">排序依据(加空格)排序方式</param> /// <returns>IOrderedQueryable</returns> public static IOrderedQueryable<T> OrderBy<T>(this IQueryable<T> source, string value) { string[] arr = value.Split(' '); string Name = arr[1].ToUpper() == "DESC" ? "OrderByDescending" : "OrderBy"; return ApplyOrder<T>(source, arr[0], Name); } /// <summary> /// Linq动态排序再排序 /// </summary> /// <typeparam name="T">T</typeparam> /// <param name="source">要排序的数据源</param> /// <param name="value">排序依据(加空格)排序方式</param> /// <returns>IOrderedQueryable</returns> public static IOrderedQueryable<T> ThenBy<T>(this IOrderedQueryable<T> source, string value) { string[] arr = value.Split(' '); string Name = arr[1].ToUpper() == "DESC" ? "ThenByDescending" : "ThenBy"; return ApplyOrder<T>(source, arr[0], Name); } static IOrderedQueryable<T> ApplyOrder<T>(IQueryable<T> source, string property, string methodName) { Type type = typeof(T); ParameterExpression arg = Expression.Parameter(type, "a"); PropertyInfo pi = type.GetProperty(property); Expression expr = Expression.Property(arg, pi); type = pi.PropertyType; Type delegateType = typeof(Func<,>).MakeGenericType(typeof(T), type); LambdaExpression lambda = Expression.Lambda(delegateType, expr, arg); object result = typeof(Queryable).GetMethods().Single( a => a.Name == methodName && a.IsGenericMethodDefinition && a.GetGenericArguments().Length == 2 && a.GetParameters().Length == 2).MakeGenericMethod(typeof(T), type).Invoke(null, new object[] { source, lambda }); return (IOrderedQueryable<T>)result; } } }
------解决方案--------------------
动态构建OrderBy的Lambda表达式
http://blog.csdn.net/Sandy945/archive/2010/07/14/5735326.aspx
------解决方案--------------------
from y in db.ViewCompanys order by y.filed1 ,y.fiel2 select y