zoukankan      html  css  js  c++  java
  • 补充三篇文章LINQ语法一

     LINQ即语言集成查询,是.NET Framework 3.5中新增的功能。其功能类似于数据库中的SQL语句(实际上LINQ就是针对.NET Framework的SQL):提供标准的、易于学习的查询和更新数据模式。
    从from开始
    用过SQL的朋友都知道,最简单的SQL语句SELECT record FROM tableName:获取表中的所有记录,那么对应于LINQ,其语法如下:
    from record in tableName select record。
    明显的差异是将from语句放到了句首,此种语法方式只是为了适应Visual Studio中智能提示(试想如果将from子句放在后面,先输入select语句,此时select的对象类型尚不确定,智能提示无法做出相应提示)
    SQL语句是从数据库表中查询出记录,而LINQ适应的数据源更广,包括SQL Server数据库、XML文档、ADO.NET数据集以及所有支持IEnumerable及IEnumerable<T>接口的任意对象集合。

    LINQ只是一种语法
    LINQ查询语句实际上和我们常用的foreach语句相似:中间语言(IL)中并没有对应的foreach语句,编译器最终会将foreach语句转换为一些列的语句块,例如:

    string[] strs = new String[] {"One","Two","Three" };
    foreach (String s in strs)
    {
        Console.WriteLine(s);
    }

    转换为:

    string[] strs = new String[] {"One","Two","Three" };
    IEnumerator e = strs.GetEnumerator();
    while (e.MoveNext())
    {
        Console.WriteLine(e.Current);
    }

    在.NET Framework 3.5中为IEnumerable<T>接口加入了大量的扩展方法,这些方法为LINQ提供了实现基础(就像IEnumerable中GetEnumerator方法为foreach提供实现基础一样)
    例如,IEnumerable中的Where扩展方法,它和LINQ中的where子句对应,用于筛选数据:

    //使1用?Where方?法¨
     IEnumerable<String> query = strs.Where(s => s.StartsWith("T"));
    foreach (String s in query)
    {
        Console.WriteLine(s);
    }
    //使1用?query语?句?
    query = from s in strs
            where s.StartsWith("T")
            select s;
    foreach (String s in query)
    {
        Console.WriteLine(s);
    }

    题外话:如何为已知类型扩展方法:只需一个静态类和静态方法,在静态方法中参数使用this关键字,以下为String类型新增一个AppendA方法:

    public static class Extension
    {
        public static String AppendA(this String ins)
        {
            return ins + "AAA";
        }
    }

    var关键字与匿名类型
    var关键字指示编译器推断出变量的类型,例如:
    var s = "Hello";
    编译器最终将s变量推断为String类型,即最终按
    String s = "Hello";
    来生成中间代码
    在LINQ中我们可以通过var关键字来声明查询对象,而无需清楚最终我们查询返回的具体类型:

    var query = from s in strs
            where s.StartsWith("T")
            select s;

    另一种情况,有时我们只需要返回对象的某些属性,此时我们无需定义返回数据的类型,直接使用匿名类型:

      var xxx = new { F1 = "Hello", F2 = "Hello2" };

    以下查询只返回Programer类的Name和Position属性:

    public class Programer
        {
            public String Name { get; set; }
            public String Language { get; set; }
            public String Position { get; set; }
            public Programer()
            {
            }
        }
    Programer[] ps = new Programer[] { 
        new Programer(){ Name="张?三y", Language="C#", Position="Leader"},
        new Programer(){ Name="李?四?", Language="C#", Position="Coder"},
        new Programer(){ Name="王?五?", Language="Java", Position="Coder"}
    };
    var queryPs = from p in ps
                  where p.Language == "C#"
                  select new { Name = p.Name, Position = p.Position };//返回了一个新类型
               
    foreach (var p in queryPs)
    {
        Console.WriteLine(String.Format("Name:{0}\t\tPosition:{1}", p.Name, p.Position));
    }

    查询的执行时间
    上述例子中LINQ语句是在foreach语句时才真正执行的,定义时只是定义了查询语句,在进入foreach枚举时才真正执行查询语句。如果我们在定义时需要立即返回查询结果可以使用ToArray或ToList方法(这两个方法也是在.Net Fromework 3.5中为IEnumerable接口新增的扩展方法)。

    var queryPs = (from p in ps
                  where p.Language == "C#"
                  select new { Name = p.Name, Position = p.Position }).ToArray();
  • 相关阅读:
    0x02 枚举、模拟、递推
    0x01 位运算
    bzoj3529: [Sdoi2014]数表
    bzoj5216: [Lydsy2017省队十连测]公路建设
    POJ1789Truck History
    最小生成树模板
    POJ1258Agri-Net
    POJ1860Currency Exchange(SPFA)
    POJ3083Children of the Candy Corn
    POJ2503Babelfish
  • 原文地址:https://www.cnblogs.com/wangchuang/p/2989285.html
Copyright © 2011-2022 走看看