【问题标题】:Dynamic Order (SQL ORDERBY) in LINQ CompiledQueryLINQ CompiledQuery 中的动态顺序 (SQL ORDERBY)
【发布时间】:2009-09-15 04:24:12
【问题描述】:

如何在我的 LINQ CompiledQuery 中创建动态 ORDERBY(例如,提供 Order Field 和 Direction 作为编译查询的参数)?

【问题讨论】:

  • 有人吗?我正要问同样的事情。

标签: linq compiled-query


【解决方案1】:

我想我找到了:

看看这个link。它将指向包含动态 Linq 查询库的 VS2008 代码示例,其中包含以下扩展方法。这将允许你去:

Object.OrderBy("ColumnName");

这里是扩展方法,但你可能想要整个库。

public static IQueryable<T> OrderBy<T>(this IQueryable<T> source, string ordering, params object[] values) {
    return (IQueryable<T>)OrderBy((IQueryable)source, ordering, values);
}

public static IQueryable OrderBy(this IQueryable source, string ordering, params object[] values) {
    if (source == null) throw new ArgumentNullException("source");
    if (ordering == null) throw new ArgumentNullException("ordering");
    ParameterExpression[] parameters = new ParameterExpression[] {
        Expression.Parameter(source.ElementType, "") };
    ExpressionParser parser = new ExpressionParser(parameters, ordering, values);
    IEnumerable<DynamicOrdering> orderings = parser.ParseOrdering();
    Expression queryExpr = source.Expression;
    string methodAsc = "OrderBy";
    string methodDesc = "OrderByDescending";
    foreach (DynamicOrdering o in orderings) {
        queryExpr = Expression.Call(
            typeof(Queryable), o.Ascending ? methodAsc : methodDesc,
            new Type[] { source.ElementType, o.Selector.Type },
            queryExpr, Expression.Quote(Expression.Lambda(o.Selector, parameters)));
        methodAsc = "ThenBy";
        methodDesc = "ThenByDescending";
    }
    return source.Provider.CreateQuery(queryExpr);
}

【讨论】:

  • 这无法编译(CompiledQuery.Compile())。
【解决方案2】:

我会这样做,首先您真正需要的是一种通过字符串访问对象上的属性值的方法。你可以使用反射,但它很慢。所以使用这个基于http://stefan.rusek.org/Posts/LINQ-Expressions-as-Fast-Reflection-Invoke/3/测试的辅助类方法

    public static class LINQHelper
    {
        public static IComparable OrderByProperty<TClass>(TClass item, 
                                                          string propertyName)
        {
            var t = Expression.Parameter(typeof(TClass), "t");
            var prop = Expression.Property(t, propertyName);
            var exp = Expression.Lambda(prop, t).Compile();
            return (IComparable)exp.DynamicInvoke(item);
        }

     }

在您希望按属性名称字符串排序的代码中,在此示例 col1 中,您只需执行以下操作。

     var myQuery = from i in Items
                   select i;

     myQuery.OrderBy(i=>LINQHelper.OrderByProperty(i,"col1"));

希望这会有所帮助。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-06-02
    • 2011-01-02
    • 1970-01-01
    相关资源
    最近更新 更多