如何使用动态字符串参数执行 OrderBy? [英] How can I do an OrderBy with a dynamic string parameter?
本文介绍了如何使用动态字符串参数执行 OrderBy?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我想这样做:
var orderBy = "Nome, Cognome desc";
var timb = time.Timbratures.Include("Anagrafica_Dipendente")
.Where(p => p.CodDipendente == 1);
if(orderBy != "")
timb = timb.OrderBy(orderBy);
是否有接受字符串参数的 OrderBy
重载可用?
Is there an OrderBy
overload available that accepts a string parameter?
推荐答案
绝对可以.您可以使用 LINQ 动态查询库,找到 在 Scott Guthrie 的博客上.CodePlex 上还有一个可用的更新版本.
Absolutely. You can use the LINQ Dynamic Query Library, found on Scott Guthrie's blog. There's also an updated version available on CodePlex.
它允许您通过传入字符串参数来创建 OrderBy
子句、Where
子句以及几乎所有其他内容.它非常适合创建用于排序/过滤网格等的通用代码.
It lets you create OrderBy
clauses, Where
clauses, and just about everything else by passing in string parameters. It works great for creating generic code for sorting/filtering grids, etc.
var result = data
.Where(/* ... */)
.Select(/* ... */)
.OrderBy("Foo asc");
var query = DbContext.Data
.Where(/* ... */)
.Select(/* ... */)
.OrderBy("Foo ascending");
这篇关于如何使用动态字符串参数执行 OrderBy?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文