LINQ to SQL语句(5)之Order By

本文详细介绍了 LINQ 中 OrderBy 操作的多种使用方式,包括简单的升序排序、带条件的排序、降序排序、复合排序以及结合 GroupBy 的排序等。通过具体实例展示了如何灵活运用这些技巧进行数据组织。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转载地址: http://www.prg-cn.com/article-4470-1.html

Order By操作

适用场景:对查询出的语句进行排序,比如按时间排序 等等。

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

1.简单形式

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

  1. var q =
  2.   from e in db.Employees
  3.   orderby e.HireDate
  4.   select e;
复制代码

说明:默认为升序

2.带条件形式

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

  1. var q =
  2.   from o in db.Orders
  3.   where o.ShipCity == "London"
  4.   orderby o.Freight
  5.    select o;
复制代码

语句描述:使用where和orderby按运费进行排序。

3.降序排序

  1. var q =
  2.   from p in db.Products
  3.   orderby p.UnitPrice descending
  4.   select p;
复制代码

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 对这组产品进行排序。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值