LINQ即语言集成查询,是.NET Framework 3.5中新增的功能。其功能类似于数据库中的SQL语句(实际上LINQ就是针对.NET Framework的SQL):提供标准的、易于学习的查询和更新数据模式。 从from开始 用过SQL的朋友都知道,最简单的SQL语句SELECT record FROM tableName:获取表中的所有记录,那么对应于LINQ,其语法如下: from record in tableName select record。 明显的差异是将from语句放到了句首,此种语法方式只是为了适应Visual Studio中智能提示(试想如果将from子句放在后面,先输入select语句,此时select的对象类型尚不确定,智能提示无法做出相应提示) SQL语句是从数据库表中查询出记录,而LINQ适应的数据源更广,包括SQL Server数据库、XML文档、ADO.NET数据集以及所有支持IEnumerable及IEnumerable<T>接口的任意对象集合。 LINQ只是一种语法 LINQ查询语句实际上和我们常用的foreach语句相似:中间语言(IL)中并没有对应的foreach语句,编译器最终会将foreach语句转换为一些列的语句块,例如:
隐藏行号复制代码?C#
string[] strs = new String[] {"One","Two","Three" };
foreach (String s in strs)
{
Console.WriteLine(s);
}
转换为:
隐藏行号复制代码?C#
string[] strs = new String[] {"One","Two","Three" };
var关键字与匿名类型 var关键字指示编译器推断出变量的类型,例如: var s = "Hello"; 编译器最终将s变量推断为String类型,即最终按 String s = "Hello"; 来生成中间代码 在LINQ中我们可以通过var关键字来声明查询对象,而无需清楚最终我们查询返回的具体类型:
隐藏行号复制代码?C#
var query = from s in strs
where s.StartsWith("T")
select s;
另一种情况,有时我们只需要返回对象的某些属性,此时我们无需定义返回数据的类型,直接使用匿名类型:
1: var xxx = new { F1 = "Hello", F2 = "Hello2" };
2:
以下查询只返回Programer类的Name和Position属性:
隐藏行号复制代码?C#
public class Programer
{
public String Name { get; set; }
public String Language { get; set; }
public String Position { get; set; }
public Programer()
{
}
}
隐藏行号复制代码?C#
Programer[] ps = new Programer[] {
new Programer(){ Name="张?三y", Language="C#", Position="Leader"},
new Programer(){ Name="李?四?", Language="C#", Position="Coder"},
new Programer(){ Name="王?五?", Language="Java", Position="Coder"}
};
var queryPs = from p in ps
where p.Language == "C#"
select new { Name = p.Name, Position = p.Position };
LINQ即语言集成查询,是.NET Framework 3.5中新增的功能。其功能类似于数据库中的SQL语句(实际上LINQ就是针对.NET Framework的SQL):提供标准的、易于学习的查询和更新数据模式。从from开始 用过SQL的朋友都知道,最简单的SQL语句SELECT record FROM tableName:获取表中的所有记录,那么对应于LINQ,其语法如下: