查询语句:
int[] values = { 30, 5, 99, 77, 102, 8, 12, 35 };
var result = from item in values //foreach(int item in values)
where item > 20
select 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>0
orderby i descending
select "[" + i + "]";
//基于类型推断的考虑,select在最后,from在最前
foreach (var i in e1)
{
Console.WriteLine(i);
}
//根据一个DBPerson对象,过滤出年龄大于20的人,按照年龄排序
//并且根据FirstName、LastName拼出Name