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

时间:2022-06-01 17:44:08
我的思路是这样的,通过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参数不用管,主要解决这个,谢谢了。

5 个解决方案

#1


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

当然 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;
}

#3


引用 1 楼 fangxinggood 的回复:
直接下个 dynamic.cs 直接用string orderby 。。。

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

你好 能说的详细点吗?没用过。。。

#4


引用 2 楼 orain 的回复:
你这样写肯定不行了,在 Linq 中,Order By 后跟的是变量名,而你给一个字符串,肯定不对了。
你可以这样写:
var productlist = from p in datacontext.ViewICBCProduct where p.ClassProduct == cp select p;
switch (str1)
{
case "idasc":
productlis……

嗯 这样是可以的,后来就打算这样做。

#5


排序字段不多的话,就采用2楼的方法吧

#1


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

当然 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;
}

#3


引用 1 楼 fangxinggood 的回复:
直接下个 dynamic.cs 直接用string orderby 。。。

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

你好 能说的详细点吗?没用过。。。

#4


引用 2 楼 orain 的回复:
你这样写肯定不行了,在 Linq 中,Order By 后跟的是变量名,而你给一个字符串,肯定不对了。
你可以这样写:
var productlist = from p in datacontext.ViewICBCProduct where p.ClassProduct == cp select p;
switch (str1)
{
case "idasc":
productlis……

嗯 这样是可以的,后来就打算这样做。

#5


排序字段不多的话,就采用2楼的方法吧