如何在我的LINQ CompiledQuery中创建动态ORDERBY(例如,为编译查询提供Order Field和Direction作为参数)?LINQ CompiledQuery中的动态顺序(SQL ORDERBY)
1
A
回答
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);
}
+2
虽然这不能被编译(CompiledQuery.Compile())。 – Alex 2009-09-24 06:07:12
1
我会这样做,首先你真正需要的是一种通过对象上的字符串访问属性值的方法。你可以使用反射,但它很慢。因此,使用了基于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"));
希望这会有所帮助。
相关问题
- 1. 在Linq的动态顺序
- 2. SQL Server中多列的动态顺序
- 3. LINQ to SQL动态排序
- 4. 动态Linq顺序按用户定义的顺序
- 5. 动态表名linq-to-sql动态LINQ
- 6. SQL Server的动态顺序通过
- 7. LINq to SQL困难的排序顺序
- 8. 动态地在linq中设置按键的顺序
- 9. 如何采取一个LINQ CompiledQuery
- 10. 转换LINQ表达式使用CompiledQuery
- 11. 动态SQL动态SQL到MS.NET SQL Server 2008 VB.NET动态LINQ
- 12. LINQ到SQL动态排序问题
- 13. LINQ到SQL动态排序问题
- 14. 的LINQ to SQL - 动态
- 15. LINQ to SQL布尔评估的顺序
- 16. 续集中的动态排序顺序
- 17. LINQ根据动态列表更新数据库排序顺序
- 18. 动态顺序通过不使用动态SQL?
- 19. 动态LINQ中的SQL Like关键字
- 20. Linq to SQL中的动态表名称
- 21. LINQ to SQL查询中的动态表
- 22. Linq到实体顺序由sql
- 23. Linq to SQL Association组合框顺序
- 24. LINQ to SQL插入顺序GUID
- 25. Linq 2 Sql动态查询
- 26. JDBI SQL对象查询中的动态顺序
- 27. 动态数据中字段的顺序?
- 28. Apache Derby中的SQL查询
- 29. Linq中检索行SQL ID为动态
- 30. 如何在SQL Server中动态设置顺序?
有人吗?我正要问同样的事情。 – Martin 2009-09-24 02:13:31