智商和排序

  • 本文关键字:排序 linq
  • 更新时间 :
  • 英文 :

似乎

在收到IQueryable后,我无法修改查询以启用排序。这是代码片段。我的印象是,有了IQueryable(而不是做IEnumerable),我应该能够做我正在尝试的事情。

using (oc1 = new NWEntities())
{
    string customerid = "ALFKI";
    var q = GetOrders((o) => o.CustomerID == customerid);
    q.OrderBy(o => o.ShipCity);   // DOES NOT WORK !!!!!!!!
    foreach (var x in q)
    {
        Console.WriteLine(string.Format("Order#:{0} City:{1} for Customer {2}",
                                    x.OrderID,
                                    x.ShipCity,
                                    customerid));
    }
}
// Returns IQueryable
IQueryable<Order> GetOrders(Expression<Func<Order, Boolean>> predicate)
{            
    return (oc1.Orders.Where(predicate));            
}

输出不知何故未按城市排序。我错过了一些明显的东西吗?谢谢你的时间。

您需要将

OrderBy的结果存储在另一个变量中。 您对列表进行了排序,然后静默地删除了结果,并对原始列表进行了迭代:

var q = GetOrders(...);
// notice I store in **q2**
var q2 = q.OrderBy(o => o.ShipCity);
foreach (var x in q2)

相关内容

  • 没有找到相关文章

最新更新