linq是什么呢?
LINQ,语言集成查询(Language Integrated Query),他提供N多查询方法,基本的是select(),where(),orderby()和groupby()这几种,是不是很熟悉,sql中不是也有吗?那么他们有什么区别吗?下面再说.
先从一个简单的实例上理解一下linq是如何使用的.
如实现这个功能:从 numbers 数组中提取偶数并降序排列
以前是这么做的
- int[]numbers = new int[] { 6, 4, 3, 2, 9, 1, 7, 8, 5 };
- List<int>even = new List<int>();
- foreach(int number in numbers)
- {
- if (number % 2 == 0)
- {
- even.Add(number);
- }
- }
- even.Sort();
- even.Reverse();
用linq你就可以这样实现了,简洁了很多
- int[]numbers = new int[] { 6, 4, 3, 2, 9, 1, 7, 8, 5 };
- var even= numbers
- .Where(p => p % 2 == 0)
- .Select(p => p)
- .OrderByDescending(p => p);
上面的那段代码解释就是,第一行就是new一个数组,并赋值。然后对于数组numbers进行where操作,要p%2==0也就是偶数,在这里p就是numbers数组中某一个数,如果是一个对象集合,那么p就是一个对象。select操作p=>p,就是返回整个p,这个是数值看不大出来,如果是对象的话,对象有很多属性,你就可以选择返回某些属性如p=>p.id.最后一句就是根据根据p值倒序排序.
而p=>p,就是lambda表达式.lambda表达式本质上就是一个匿名方法,而且是一个进一步简化的匿名方法,它依附于委托.
它的一般形式:
(输入参数列表)=>{语句序列} 如 x => {return x+1;}
=> :称为Lambda 运算符,读为“goesto”
它的发展过程是在C#1.0中使用的委托,C#2.0中添加了匿名方法,C#3.0中添加了lambda表达式.
C#1.0
首先定义一个委托:
- delegatestring ProcessString( string input );
委托的实例化和使用,
有一个方法LowerIt,用于将输入的值,转为小写.
- privatestring LowerIt(string input)
- {
- return input.ToLower();
- }
实例化委托,此时委托p就是这个LowerIt()方法.委托的实例化就是将委托变量p指向了LowerIt()方法,所以调用p("ABCD")也就是调用LowerIt("ABCD")
- ProcessStringp = new ProcessString( LowerIt );
- Console.WriteLine(p("ABCD"));
在C#2.0中,添加了匿名方法特性
- delegatestring ProcessString( string input );
- // 匿名方法方式,这里就没有上面的LowerIt这个方法名了.
- ProcessStringp = delegate( string input )
- {
- return input.ToLower();
- };
- Console.WriteLine(p("ABCD"));
而在C#3.0中使用简洁的lamdba表达式,上段代码就可以变为这样.
- delegatestring ProcessString( string input );
- // Lambda 表达式方式,p还是用于将input转为小写
- ProcessStringp = input => input.ToLower();
- Console.WriteLine(p("ABCD"));"font-family: Calibri; ">
介绍完一些理论知识,说说我在实际应用时,遇到的问题.
尽管我在使用的时候只使用过select和where,我第一次使用的时候,以为select是选择的意思,然后写var obj = objs.select(p=>p.Code='123') ,我以为他会给我找出所有Code为123的对象给我,后来发现不是这样的,他给我的是一个一堆123.就是说,假如objs有10条数据,Code为123的有3条,我是想查出这三条数据,但是最后查出10条,并且都是123,而且只会返回Code.所以obj其实是string[]类型.obj[0]到obj[9]都是123.所以应该用where操作.
如果把他们写成sql语句的样式,可能我会更容易理解.select code from table1 where p.Code='123'.这条语句只会返回Code一列给我,所以.select(p=>p.Code),只会返回Code一列给我.
写完这篇博客,对于linq和lambda表达式有了一点简单的了解,以后可以多多了解。