Language Integrated Query 语言集成查询 可以使得查询操作通过编程语言自身来表示,而不是嵌入字符串SQL语句。
LINQ to Objects 主要负责对象的查询 LINQ to XML 主要负责XML的查询 LINQ to ADO.NET 主要负责数据库的查询
1.获取数据Select(); Select()方法在时候用的时候,要求传递一个委托实例。 示例
static void Main(string[] args)
{
int[] nums = { 1, 7, 5, 8, 9, 6, 1, 22, 11, 89 };
var list = nums.Select(k=>k*k);
foreach(int a in list)
{
Console.WriteLine(a);
}
Console.ReadKey();
}
运行结果:
Select()方法里面是一个Lambda表达式 返回结果是一个迭代器(Iterator)
2.筛选数据:Where()方法 Where()方法是一个扩展泛型方法 Where()方法使用的时候要求传递一个委托示例,但要求该实例是一个判断条件,返回值为bool类型 示例
static void Main(string[] args)
{
int[] nums = { 1, 7, 5, 8, 9, 6, 1, 12, 11, 10 };
var list = nums.Where(k => k % 2 == 0);
foreach(int a in list)
{
Console.WriteLine(a);
}
Console.ReadKey();
}
运行结果:
3.排序数据:OrderBy() OrderBy()是一个扩展方法 OrderBy()里面的参数要求传递一个排序的字段,默认按照升序排列 降序使用OrderByDescending() 示例
static void Main(string[] args)
{
int[] nums = { 1, 7, 5, 8, 9, 6, 1, 12, 11, 10 };
var list = nums.OrderByDescending(i => i);
foreach(int a in list)
{
Console.WriteLine(a);
}
Console.ReadKey();
}
运行结果
4.分组数据:GroupBy()方法 GroupBy()里面的参数要求传递一个分组的字段 示例
static void Main(string[] args)
{
string[] nums = {"张三","张四","李一","张五","王七","王十"};
var list = nums.GroupBy(i => i.Substring(0,1));
foreach(var a in list)
{
Console.WriteLine("分组条件:"+a.Key);
foreach (var k in a)
{
Console.WriteLine(k);
}
}
Console.ReadKey();
}
运行结果