Linq语句和Lambda表达式

这篇文章介绍了LINQ作为.NET Framework 3.5中的新特性,它提供了与SQL类似但适用于更广泛数据源的查询能力。LINQ的from语句位于句首以方便智能提示,且其实现方式与foreach相似,通过编译器转换。文章还提到了var关键字用于匿名类型的推断,以及IEnumerable接口的扩展方法在LINQ中的关键作用。此外,文中还展示了如何使用Lambda表达式进行条件筛选。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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接口的任意对象集合。

LINQ只是一种语法:
LINQ查询语句实际上和我们常用的foreach语句相似:中间语言(IL)中并没有对应的foreach语句,编译器最终会将foreach语句转换为一些列的语句块,例如:
string[] strs = new String[] {“One”,“Two”,“Three”};
foreach(String s in strs)
{Console.WriteLine(s);}
转换为:
string[] strs = new String[]{“One”,“Two”,“Three” };
while(e.MoveNext())
{ Console.WriteLine(e.Current);}

只需一个静态类和静态方法就可以为已知类型扩展方法,在静态方法中参数使用this关键字,以下为String类型新增一个AppendA方法:
public static class Extension{
public static String AppendA(this String ins)
{ return ins + “AAA”;}
var关键字与匿名类型
var关键字指示编译器推断出变量的类型,例如:
var s = “Hello”;
编译器最终将s变量推断为String类型,即最终按
String s = “Hello”;
来生成中间代码
在LINQ中我们可以通过var关键字来声明查询对象,而无需清楚最终我们查询返回的具体类型。

在.NET Framework 3.5中为IEnumerable接口加入了大量的扩展方法,这些方法为LINQ提供了实现基础(就像IEnumerable中GetEnumerator方法为foreach提供实现基础一样)
例如,IEnumerable中的Where扩展方法,它和LINQ中的where子句对应,用于筛选数据。

查询的执行时间:
上述例子中LINQ语句是在foreach语句时才真正执行的,定义时只是定义了查询语句,在进入foreach枚举时才真正执行查询语句。如果我们在定义时需要立即返回查询结果可以使用ToArray或ToList方法(这两个方法也是在.Net Fromework 3.5中为IEnumerable接口新增的扩展方法)。

条件筛选 Lambda表达式:Lambda运算符=>,运算符左侧是参数(如果有),右侧是表达式或者语句块:
if (AcademeID > 0)
{
listStudent = listStudent.Where(m => m.AcademeID == AcademeID).ToList();
}
if (GradeID > 0)
{
listStudent = listStudent.Where(m => m.GradeID == GradeID).ToList();
}
if (ClassID > 0)
{
listStudent = listStudent.Where(m => m.ClassID == ClassID).ToList();
}

if (!string.IsNullOrEmpty(StudentDetail))
{
listStudent = listStudent.Where(m => m.StudentName.Contains(StudentDetail) || m.StudentNumber.Contains(StudentDetail)).ToList();
}
这段代码是我前不久上课学的,前三句表示下拉框,最后一句表示文本框。
有写的不好的地方还望大家指出,谢谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值