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;呢?