LINQ TO OBJECT

来源:互联网 发布:宝贝详情淘宝网衣服 编辑:程序博客网 时间:2024/05/20 10:51

LINQ .Net3.5提供的查询语言集合

源文http://www.tudou.com/programs/view/2I0rd1ql6js/

注意:

1必须创建.NET3.5环境的应用程序才可以使用,3.0也可以

2需要引入

using System.Linq;

using System.Data.Linq;

using System.Xml.Linq;

3C#对LINQ提供的支持

3.1 对象初始化器

          Student s=new Student();

          s.id=1;s.name="Jerry";

          //LINQ支持

          Student s=new {id=1,name="Jerry"};    //对声明构造函数的简化,节省代码就是减少出错的机会。

3.2 隐式类型 var

          var 创建的对象是直接继承于Object的数据类型,强类型,可通过上下文进行定义的

   //形象的理解,var 是javascript的变量修饰符,而javascript变量是可以通过值,直接获得数据类型的,当然javascrip所有数据类型都是Ojbect类型,因此C#引入var是要使用javascript var类型的优点。

   //如:var s=new {id=1,name="Jerry"};  //我们可以访问s变量,甚至是方法。但无法知道s的类型。

   //如:var s=new {id=1;name="Jerry"};

                   Type type=s.getType();

                   Console.WriteLine(type.name);     //看看结果,一个运行时随即产生的名字

3.3 扩展静态方法

3.4 Lambda表达式

   是对匿名方法的改进 =>

4 LINQ常用操作

包括查询语法Lambda表达式语法方式,只是在表现风格上有所不同

先定义一个类,便于使用

public class Student
    {
        public string id {get;set;}
        public double english {get;set;}
        public double computer {get;set;}
        public double math {get;set;}
        public double total { get {return english+computer+math; } }
        public double average { get { return total / 3; } }
    }

实例化之  //这对象的来源就多了,xml,webservice,数据库,业务逻辑,系统内存

var list = new List<Student>();
            Random r = new Random();
            for (int i = 0; i < 50; i++)
            {
                Student s = new Student();
                s.id = i.ToString("00");
                s.english = r.Next(0,100);
                s.math = r.Next(0, 100);
                s.computer = r.Next(0, 100);
                list.Add(s);
            }

4.1投影

针对数据库而言的一个概念

   如:统计平均成绩在60分以上的学生人数,不调用类的方法,只是模拟对结合的查询

   list.Count(g => (g.computer + g.english + g.math) / 3 >=60));

   //foreach (Student s in list)
         //{
         //    Console.WriteLine(s.computer);
         //}

4.2选择

   //var result = from ss in list
         
//      select new { ss.id, ss.total, ss.average };                     //匿名类型   
         
//var result = list.Select( ss => new { ss.id, ss.total, ss.average });//和上面等价

   //遍历
         
// list.ForEach(s => { Console.WriteLine("total:{0}", s.math + s.computer + s.english); });
         
// list.ForEach(s => { Console.WriteLine( s.math + s.computer + s.english); });

4.3排序

   //查询方式

     var result = from ss in list
                         orderby ss.average descending
                         select ss;

   //表达式方式

    var result = list.OrderByDescending(ss => ss.average);

    //查询平均成绩>60的学生ID
           /*
           var result = from ss in list where ss.average > 60 select ss;                  
           */
           //var result = list.Where(ss => ss.average >= 70);
           /*
           foreach (var s in result)
           {
               Console.WriteLine("id:{0},ave{1}", s.id, s.average);
           }

4.4数据分页(这个太好了,在我还是初级程序员的时候,公司有个伪高人就是封装了分页存储过程的Web控件,然后如鱼得水了好一阵。做事情最好还是踏实点,觉得自己差不多了的时候,脑子里装不进新东西!)

Skip Take两个方法

     for (int i = 0; i < 5; i++)
            {
                Console.WriteLine("这是第:{0}页", i);
                Console.WriteLine("------------------------------------------------------------");
                var result = list.Skip(10).Take(10);
                foreach (var s in result)
                {
                    Console.WriteLine("id:{0}ave:{1}", s.id, s.average);
                }
                Console.WriteLine("------------------------------------------------------------");
            }

4.5返回单条记录

    //查找学生成绩大于90的第一名学生
           
var result = list.FirstOrDefault(s => s.math>90);
            if (result != null)
            {
                Console.WriteLine("id:{0}math:{1}",result.id,result.math.ToString("00.0"));
            }
            Console.ReadLine();  

    //知道 select top1 form user;吗?

    //那MSSql select DISTINCT name, * from user;呢?