zoukankan      html  css  js  c++  java
  • C# 高级编程(笔记5)

    第11章  LINQ

    1. LINQ查询表达式必须以from子句开头,以select或group子名结束。在这两个子句之间,可以使用where、orderby、join、left和其他from子句

    2.Where语句原型

      public static IEnumerable<Tsource> Where<Tsource>(this IEnumerable<Tsource> source, Func<Tsource, bool> predicate)
      {
          foreach (Tsource item in source)
             if (predicate(item)) //委托绑定了一个方法,该方法返回bool值,Tsource是传给该方法的参数
                   yield return item;
      }
    调用1:
               IList<StackTest> li = new List<StackTest>();
               var query =  from r in li
                            where r.ss == ""
                            select r;
    
    
    调用2:
    
                IList<StackTest> li = new List<StackTest>();
                var query2 = li.Where(m => m.name == "jau")
                               .OrderByDescending(m => m.Id)
                               .Select(m => m);

    //从上面可以看出,Where()方法是泛型接口IEnumerable<T>的一个扩展方法,这样,Where()方法就可以用于实现了IEnumerable<T>的每个类型。例如数组和List<T>类实现了IEnumerable<T>接口,所以它们都可以使用Where()方法。第二个参数是一个Func<T, bool>委托,它引用了一个返回布尔值、参数类型为T的方法。

    //因为Where()方法作为一个泛型方法实现,所以它可以用于包含在集合中的任意类型。实现了IEnumerable<T>接口的任意集合都支持它。

    //OrderByDescending()、Select()也是同样的道理

  • 相关阅读:
    Ubuntu环境下IPython的搭建和使用
    智能移动导游解决方案简介
    企业文化、团队文化与知识共享
    CoinPunk项目介绍
    Insight API开源项目介绍
    比特币Bitcoin源代码安装编译
    Javascript单元测试Unit Testing之QUnit
    Node.js的UnitTest单元测试
    Node.js调试
    Alfresco 4 项目介绍
  • 原文地址:https://www.cnblogs.com/notebook2011/p/2970336.html
Copyright © 2011-2022 走看看