我想使用 OrderBy("columnName")。
我看到可以通过编写扩展方法或使用反射来实现。
我正在使用 NPoco,但无法编写扩展方法。
IQueryProvider<Sample> query = DbConnection.Query<Sample>();
我想要做:
var res = query.OrderByField("columnName");
我想使用类似的东西:
public static IQueryable<T> OrderByField<T>(this IQueryable<T> q, string SortField, bool Ascending)
{
var param = Expression.Parameter(typeof(T), "p");
var prop = Expression.Property(param, SortField);
var exp = Expression.Lambda(prop, param);
string method = Ascending ? "OrderBy" : "OrderByDescending";
Type[] types = new Type[] { q.ElementType, exp.Body.Type };
var mce = Expression.Call(typeof(Queryable), method, types, q.Expression, exp);
}
由于我传递的是 IQueryProvider 而不是 IQueryable,因此上述方法不起作用。