查询语句:
int[] values = { 30, 5, 99, 77, 102, 8, 12, 35 };var result = from item in values //foreach(int item in values)where item > 20select item;
和sql语句不同,linq中select放到最后(方便类型推断)。in后是要进行处理的集合,from后的变量是values中每个元素的变量(联想foreach),select后是查询结果,result是select结果变量类型的泛型的IEnumerable,注意是泛型的IEnumerable 。linq关键时刻能救人一命。
练习:
1、从字符串数组中将长度小于5的元素返回;
2、一个字符串数组中所有元素都是整数的表示形式,将他们中大于100的以int序列返回;{"1","25","250","388","99"}
3、将一个姓名为Key、年龄为value的Dictionary中年龄大于20的人的姓名用“,”分割打印出来。//ToArray(),Join
4、将 "ajax,javascript,jquery"字段中的单词加上【】输出出来。select “[”+item+”]”
5、一个Dictionary<string,int>中是key为姓名,value为年龄的数据,将其中年龄大于20的人依次输出到含有Name、Age属性的匿名类型的序列中。select new {}
6、一个Dictionary<string,int>中是key为姓名,value为年龄的数据,将其中年龄大于20的人输出到含有Name、Age属性的预定义类型Person的序列中。
int[] values = { 3, 5, 9, 8, 2, 20, -5, -9, 306 };values.OrderBy(i => i);//过滤掉负数,把数组排序,然后元素两边加[]输出IEnumerable<int> e1= values.Where(i => i > 0);var e1 = values.Where(i => i > 0);foreach (int i in e1){Console.WriteLine(i);}//=========================进化=========var e1 = values.Where(i => i > 0).OrderBy(i => i).Select(i=>"["+i+"]");foreach (var i in e1){Console.WriteLine(i);}//================进化:微软V5,效率更高更清晰=========////执行顺序是从上到下var e1 = from i in values//foreach(int i in values)where i>0orderby i descendingselect "[" + i + "]";//基于类型推断的考虑,select在最后,from在最前foreach (var i in e1){Console.WriteLine(i);}//根据一个DBPerson对象,过滤出年龄大于20的人,按照年龄排序//并且根据FirstName、LastName拼出Name