您的位置:首页 > 移动开发 > Objective-C

LINQ TO OBJECT

2011-01-21 16:07 429 查看
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;呢? 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: