隐藏

如何使用 ThenBy 方法通过使用基于方法的查询语法来查询-中间件排序

发布:2021/7/9 16:19:04作者:管理员 来源:本站 浏览次数:761

本主题中的示例演示如何使用 ThenBy 方法通过使用基于方法的查询语法来查询 AdventureWorks 销售模型 。 这些示例中使用的 AdventureWorks 销售模型从 AdventureWorks 示例数据库中的 Contact、Address、Product、SalesOrderHeader 和 SalesOrderDetail 等表生成。


本主题中的示例使用以下 using / Imports 语句:

C#


using System;

using System.Data;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Data.Objects;

using System.Globalization;

using System.Data.EntityClient;

using System.Data.SqlClient;

using System.Data.Common;


ThenBy

示例


采用基于方法的查询语法的以下示例使用 OrderBy 和 ThenBy 以返回先按姓氏后按名字排序的联系人列表。

C#


using (AdventureWorksEntities context = new AdventureWorksEntities())

{

   IQueryable<Contact> sortedContacts = context.Contacts

       .OrderBy(c => c.LastName)

       .ThenBy(c => c.FirstName);


   Console.WriteLine("The list of contacts sorted by last name then by first name:");

   foreach (Contact sortedContact in sortedContacts)

   {

       Console.WriteLine(sortedContact.LastName + ", " + sortedContact.FirstName);

   }

}


ThenByDescending

示例


以下示例使用 OrderBy 和 ThenByDescending 方法以首先按标价排序,然后执行产品名称的降序排序。

C#


using (AdventureWorksEntities context = new AdventureWorksEntities())

{

   IOrderedQueryable<Product> query = context.Products

       .OrderBy(product => product.ListPrice)

       .ThenByDescending(product => product.Name);


   foreach (Product product in query)

   {

       Console.WriteLine("Product ID: {0} Product Name: {1} List Price {2}",

           product.ProductID,

           product.Name,

           product.ListPrice);

   }

}


请参阅


   LINQ to Entities 中的查询