Linq-排序Order By

2019年9月18日10:39:52 评论 49

适用场景

对查询出的语句进行排序,比如按时间排序等等。

说明:按指定表达式对集合排序;延迟,:按指定表达式对集合排序;延迟,默认是升序,加上descending表示降序,对应的扩展方法是OrderBy和OrderByDescending

1.简单形式

这个例子使用 orderby 按员工日期对员工进行排序:

  1. var q =
  2.     from e in db.Employes
  3.     orderby e.Birthday
  4.     select e;

说明:默认为升序

2.带条件形式

注意:Where和Order By的顺序并不重要。而在T-SQL中,Where和Order By有严格的位置限制。

  1. var q =
  2.     from e in db.Employes
  3.     where e.Sex == 1
  4.     orderby e.Birthday
  5.     select e;

语句描述:使用where和orderby按性别是男且按生日进行排序。

3.降序排序

  1. var q =
  2.     from e in db.Employes
  3.     orderby e.Employes descending
  4.     select e;

4.ThenBy

语句描述:使用复合的 orderby 对客户进行排序:

  1. var q =
  2.     from c in db.Customers
  3.     orderby c.City, c.ContactName
  4.     select c;

说明:按多个表达式进行排序,例如先按City排序,当City相同时,按ContactName排序。这一句用Lambda表达式像这样写:

  1. var q =
  2.     .OrderBy(c => c.City)
  3.     .ThenBy(c => c.ContactName).ToList();

在T-SQL中没有ThenBy语句,其依然翻译为OrderBy,所以也可以用下面语句来表达:

  1. var q =
  2.     db.Customers
  3.     .OrderBy(c => c.ContactName)
  4.     .OrderBy(c => c.City).ToList();

所要注意的是,多个OrderBy操作时,级连方式是按逆序。对于降序的,用相应的降序操作符替换即可。

  1. var q =
  2.     db.Customers
  3.     .OrderByDescending(c => c.City)
  4.     .ThenByDescending(c => c.ContactName).ToList();

需要说明的是,OrderBy操作,不支持按type排序,也不支持匿名类。比如

  1. var q =
  2.     db.Customers
  3.     .OrderBy(c => new
  4.     {
  5.         c.City,
  6.         c.ContactName
  7.     }).ToList();

会被抛出异常。错误是前面的操作有匿名类,再跟OrderBy时,比较的是类别。比如

  1. var q =
  2.     db.Customers
  3.     .Select(c => new
  4.     {
  5.         c.City,
  6.         c.Address
  7.     })
  8.     .OrderBy(c => c).ToList();

如果你想使用OrderBy(c => c),其前提条件是,前面步骤中,所产生的对象的类别必须为C#语言的基本类型。比如下句,这里City为string类型。

  1. var q =
  2.     db.Customers
  3.     .Select(c => c.City)
  4.     .OrderBy(c => c).ToList();

5.ThenByDescending

这两个扩展方式都是用在OrderBy/OrderByDescending之后的,第一个ThenBy/ThenByDescending扩展方法作为第二位排序依据,第二个ThenBy/ThenByDescending则作为第三位排序依据,以此类推

  1. var q =
  2.     from o in db.Orders
  3.     where o.EmployeeID == 1
  4.     orderby o.ShipCountry, o.Freight descending
  5.     select o;

语句描述:使用orderby先按发往国家再按运费从高到低的顺序对 EmployeeID 1 的订单进行排序。

6.带GroupBy形式

  1. var q =
  2.     from p in db.Products
  3.     group p by p.CategoryID into g
  4.     orderby g.Key
  5.     select new {
  6.         g.Key,
  7.         MostExpensiveProducts =
  8.             from p2 in g
  9.             where p2.UnitPrice == g.Max(p3 => p3.UnitPrice)
  10.             select p2
  11.     };

语句描述:使用orderby、Max 和 Group By 得出每种类别中单价最高的产品,并按 CategoryID 对这组产品进行排序。

weinxin
微信公众号
博客微信公众号,欢迎关注。
不忘初心 牢记使命

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: