LINQ是什么?
Language Integrated Query 语言集成查询
可以使得查询操作通过编程语言自身来表示,而不是嵌入字符串SQL语句。
LINQ主要部分
LINQ to Objects 主要负责对象的查询
LINQ to XML 主要负责XML的查询
LINQ to ADO.NET 主要负责数据库的查询
LINQ查询方法
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();
}
运行结果