Linq Contains操作符介绍
创始人
2024-06-07 04:11:09
0

在向大家详细介绍Linq Contains操作符之前,首先让大家了解下投影和排序,然后全面介绍Linq Contains操作符。

投影和排序

您可能还注意到我在之前的示例中暗藏了一个投影。在使用 Max 操作符之前,LINQ 查询并不返回客户列表。而是会返回一个投影,此投影创建了包含 CustomerID 属性和 Total 属性(客户的整个消费金额)的一个新实体。投影是 LINQ 必不可少的一部分,如前一示例所示,将它们投影到序列中后,就可使用标准查询操作符来进一步处理它们。

  1. foreach (var item in   
  2. query.OrderByDescending(x => x.Total)  
  3. .ThenBy(x => x.CustomerID))  
  4. {  
  5. Console.WriteLine(item.CustomerID + " == " + item.Total);  

在该代码段中,我添加了 ThenBy 操作符和一个 Lambda 表达式,以表示序列应首先按 Total 属性降序排列,然后按投影的 CustomerID 属性升序排列。

Linq Contains操作符

如果需要确定序列中是否存在某个值,可使用标准查询操作符 Any。限定符(如 Any、All 和 Contains)会搜索元素序列,并评估序列是否满足 lambda 表达式的条件。如果需检查序列以确定某些事宜(例如:是否存在来自特定地址的客户、所有客户是否来自同一国家或者任意其他分析确定性问题),它将非常有用。

例如,以下 LINQ 查询会检查是否来自 United Kingdom 的所有客户都位于 London。它使用限定符 All 并将其传递给仅评估城市是否为 London 的 lambda 表达式。如果序列中的每个元素都满足此条件并且 lambda 表达式返回 true,然后 All 操作符会返回 true:

  1. using (Entities entities = new Entities())  
  2. {  
  3. bool allUKCustomerAreFromLondon = (from c in entities.Customers  
  4. where c.Country == "UK"  
  5. select c).All(  
  6. c => c.City.Equals("London"));  
  7. Console.WriteLine(allUKCustomerAreFromLondon ? "Yes" : "No");  

需在此查询中询问的另一问题是序列中是否有来自 United Kingdom 的 Cowes 的实体。对于此问题,可使用 Any 限定符来计算序列,如下所示:

  1. using (Entities entities = new Entities())  
  2. {  
  3. bool isOneUKCustomerFromCowes = (from c in entities.Customers  
  4. where c.Country == "UK"  
  5. select c).Any(  
  6. c => c.City.Equals("Cowes"));  
  7. Console.WriteLine(isOneUKCustomerFromCowes? "Yes" : "No");  

Linq Contains操作符在评估序列中是否包括您所查找的项目时类似于Any操作符。Any操作符可确定序列的某个项中是否存在某个值,而Linq Contains操作符则确定序列中是否存在特定项目实例。例如,在将某个对象添加到序列中之前,您可能希望确保序列中并未包含该对象。

  1. using (Entities entities = new Entities())  
  2. {  
  3. Customers customerBSBEV = (from c in entities.Customers  
  4. where c.CustomerID == "BSBEV"  
  5. select c).First();  
  6.  
  7. var customersUK = from c in entities.Customers  
  8. where c.Country == "UK"  
  9. select c;  
  10.  
  11. bool isCustomerInSequence = customersUK.Contains(customerBSBEV);  
  12.  
  13. Console.WriteLine(isCustomerInSequence? "Yes" : "No");  

有许多标准查询操作符均可定义为 Enumerable 和 Queryable 序列类的扩展方法。如我之前所示,这些操作符有助于扩展 LINQ 的功能。我还展示了结合使用多个 .NET Framework 3.5 新增强功能(包括 lambda 表达式、LINQ、实体框架和隐式类型化变量)来更加轻松地编写功能强大的代码和逻辑。

【编辑推荐】

  1. Linq表达式树简单介绍
  2. Linq和dLinq区别剖析
  3. Lambda表达式和Linq查询浅析
  4. Linq Lambda表达式概括
  5. Linq查询本质简单分析

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...