C# Linq查询

C# Linq查询

获取数据源
在 LINQ 查询中,第一步是指定数据源。 和大多数编程语言相同,在使用 C# 时也必须先声明变量,然后才能使用它。 在 LINQ 查询中,先使用 from 子句引入数据源 (customers) 和范围变量 (cust)。

queryAllCustomers is an IEnumerable<Customer>
var queryAllCustomers = from cust in customers
                        select cust;

`筛选

var queryLondonCustomers = from cust in customers
                           where cust.City == "London"
                           select cust;

排序
orderby 子句根据要排序类型的默认比较器,对返回序列中的元素排序

var queryLondonCustomers3 =
    from cust in customers
    where cust.City == "London"
    orderby cust.Name ascending
    select cust;

分组
group 子句用于对根据您指定的键所获得的结果进行分组。 例如,可指定按 City 对结果进行分组,使来自 London 或 Paris 的所有客户位于单独的组内。 在这种情况下,cust.City 是键。

// queryCustomersByCity is an IEnumerable<IGrouping<string, Customer>>
  var queryCustomersByCity =
      from cust in customers
      group cust by cust.City;

  // customerGroup is an IGrouping<string, Customer>
  foreach (var customerGroup in queryCustomersByCity)
  {
      Console.WriteLine(customerGroup.Key);
      foreach (Customer customer in customerGroup)
      {
          Console.WriteLine("    {0}", customer.Name);
      }
  }

使用 group 子句结束查询时,结果将以列表的形式列出。 列表中的每个元素都是具有 Key 成员的对象,列表中的元素根据该键被分组。 在循环访问生成组序列的查询时,必须使用嵌套 foreach 循环。 外层循环循环访问每个组,内层循环循环访问每个组的成员。
如果必须引用某个组操作的结果,可使用 into 关键字创建能被进一步查询的标识符。 下列查询仅返回包含两个以上客户的组:

// custQuery is an IEnumerable<IGrouping<string, Customer>>
var custQuery =
    from cust in customers
    group cust by cust.City into custGroup
    where custGroup.Count() > 2
    orderby custGroup.Key
    select custGroup;

联接
联接操作在不同序列间创建关联,这些序列在数据源中未被显式模块化。 例如,可通过执行联接来查找所有位置相同的客户和分销商。 在 LINQ 中,join 子句始终作用于对象集合,而非直接作用于数据库表。

var innerJoinQuery =
    from cust in customers
    join dist in distributors on cust.City equals dist.City
    select new { CustomerName = cust.Name, DistributorName = dist.Name };

在 LINQ 中,不必像在 SQL 中那样频繁使用 join,因为 LINQ 中的外键在对象模型中表示为包含项集合的属性。 例如 Customer 对象包含 Order 对象的集合。 不必执行联接,只需使用点表示法访问订单:

from order in Customer.Orders...  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C#中,LINQ(Language Integrated Query)是一种用于查询和操作各种数据源的语言集成查询技术。LINQ提供了一种统一的查询语法,可以用于查询对象集合、数据库、XML文档等各种数据源。 在给出的引用中,引用\[1\]展示了如何使用LINQ进行查询结果排序。在示例中,通过使用`orderby`关键字,可以按照指定的字段进行排序。例如,`orderby e.LevelNum, e.Name, e.Age descending`表示按照级别、姓名和年龄进行排序,其中`descending`表示降序排序。 引用\[2\]展示了如何使用LINQ进行联合查询。通过使用`from`关键字和`select`关键字,可以将两个集合进行联合查询,并输出结果。例如,`from e in empArray from l in empLeArray select new { e, l }`表示将`empArray`和`empLeArray`两个集合进行联合查询,并输出结果。 引用\[3\]展示了LINQ支持的查询环境之一,即对象集合。在示例中,通过创建`List<string>`、`Dictionary<string, string>`、`ArrayList`和`Hashtable`等对象集合,可以在LINQ中进行查询操作。 综上所述,C#中的LINQ查询可以通过使用`orderby`关键字进行结果排序,使用`from`和`select`关键字进行联合查询,并支持在对象集合中进行查询操作。 #### 引用[.reference_title] - *1* *2* *3* [C#Linq查询表达式](https://blog.csdn.net/weixin_49251429/article/details/123671040)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值