Linq to sql中,按照参数排序的问题,不知道大家遇到过这样的问题没,求指教,谢谢了先

_懒猫 2012-01-05 05:24:09
我的思路是这样的,通过URL传过来的值来对页面上的数据进行排序:
首先我传的参数是:
str1 = HttpUtility.UrlDecode(Request.QueryString["sort"].ToString());
switch (str1)
{
case "idasc":
sort = "p.ICBC_ProductId";
break;
case "pubdatedesc":
sort = "p.StartDate descending";//时间降序
break;
case "pubdateasc":
sort = "p.StartDate";//时间升序
break;
case "dpriceasc":
sort = "p.DetailPrice";价格升序
break;
case "dpricedesc":
sort = "p.DetailPrice descending";价格降序
break;
default:
break;
}

我要把上面得到的sort传到下面的方法中进行排序:
public List<ViewICBCProduct> GetProducts(string cp, string sort)
{
using (DavidnileDataContext datacontext = new DavidnileDataContext())
{
var productlist = from p in datacontext.ViewICBCProduct where p.ClassProduct == cp orderby sort descending select p;
return productlist.ToList();
}

就是根据传进来的这个sort排序,这样写不行,我调试过了,调试生成的sql语句中没有orderby语句,这里要怎么利用传进来的sort排序呢,还有一个cp参数不用管,主要解决这个,谢谢了。
...全文
157 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
myhope88 2012-01-05
  • 打赏
  • 举报
回复
排序字段不多的话,就采用2楼的方法吧
_懒猫 2012-01-05
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 orain 的回复:]

你这样写肯定不行了,在 Linq 中,Order By 后跟的是变量名,而你给一个字符串,肯定不对了。
你可以这样写:
var productlist = from p in datacontext.ViewICBCProduct where p.ClassProduct == cp select p;
switch (str1)
{
case "idasc":
productlis……
[/Quote]
嗯 这样是可以的,后来就打算这样做。
_懒猫 2012-01-05
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 fangxinggood 的回复:]

直接下个 dynamic.cs 直接用string orderby 。。。

当然 Expression Tree 也可以,但直接用现成的吧。
[/Quote]
你好 能说的详细点吗?没用过。。。
orain 2012-01-05
  • 打赏
  • 举报
回复
你这样写肯定不行了,在 Linq 中,Order By 后跟的是变量名,而你给一个字符串,肯定不对了。
你可以这样写:
var productlist = from p in datacontext.ViewICBCProduct where p.ClassProduct == cp select p;
switch (str1)
{
  case "idasc":
    productlist = productlist.OrderBy(p => p.ICBC_ProductId);
break;
}
机器人 2012-01-05
  • 打赏
  • 举报
回复
直接下个 dynamic.cs 直接用string orderby 。。。

当然 Expression Tree 也可以,但直接用现成的吧。

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧