首先我传的参数是:
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参数不用管,主要解决这个,谢谢了。
5 个解决方案
#1
直接下个 dynamic.cs 直接用string orderby 。。。
当然 Expression Tree 也可以,但直接用现成的吧。
当然 Expression Tree 也可以,但直接用现成的吧。
#2
你这样写肯定不行了,在 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;
}
你可以这样写:
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;
}
#3
你好 能说的详细点吗?没用过。。。
#4
嗯 这样是可以的,后来就打算这样做。
#5
排序字段不多的话,就采用2楼的方法吧
#1
直接下个 dynamic.cs 直接用string orderby 。。。
当然 Expression Tree 也可以,但直接用现成的吧。
当然 Expression Tree 也可以,但直接用现成的吧。
#2
你这样写肯定不行了,在 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;
}
你可以这样写:
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;
}
#3
你好 能说的详细点吗?没用过。。。
#4
嗯 这样是可以的,后来就打算这样做。
#5
排序字段不多的话,就采用2楼的方法吧