2

我想使用 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,因此上述方法不起作用。

4

1 回答 1

0

试试下面的代码

public static IQueryProvider<T> OrderByField<T>(this IQueryProvider<T> q, string SortField, bool Ascending)
{
    var param = Expression.Parameter(typeof(T), "p");
    var prop = Expression.Property(param, SortField);
    string methodName = Ascending ? "OrderBy" : "OrderByDescending";
    Expression conversion = Expression.Convert(prop, typeof(object));
    LambdaExpression lambda = Expression.Lambda(conversion, param);
    object result = typeof(IQueryProvider<T>).GetMethods().Single(
            method => method.Name == methodName)
        .Invoke(q, new object[] { lambda });
    return (IQueryProvider<T>)result;
}

然后应用查询。

var list = db.Query<Users>().OrderByField("Id",false).ToList();
于 2018-01-25T18:12:23.743 回答