LINQ(入门)
来源:互联网 发布:php get json数据 编辑:程序博客网 时间:2024/06/05 15:13
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语句转换为一些列的语句块,例如:
转换为:
在.NET Framework 3.5中为IEnumerable<T>接口加入了大量的扩展方法,这些方法为LINQ提供了实现基础(就像IEnumerable中GetEnumerator方法为foreach提供实现基础一样)
例如,IEnumerable中的Where扩展方法,它和LINQ中的where子句对应,用于筛选数据:
题外话:如何为已知类型扩展方法:只需一个静态类和静态方法,在静态方法中参数使用this关键字,以下为String类型新增一个AppendA方法:
var关键字与匿名类型
var关键字指示编译器推断出变量的类型,例如:
var s = "Hello";
编译器最终将s变量推断为String类型,即最终按
String s = "Hello";
来生成中间代码
在LINQ中我们可以通过var关键字来声明查询对象,而无需清楚最终我们查询返回的具体类型:
另一种情况,有时我们只需要返回对象的某些属性,此时我们无需定义返回数据的类型,直接使用匿名类型:
1: var xxx = new { F1 = "Hello", F2 = "Hello2" };
2:
以下查询只返回Programer类的Name和Position属性:
查询的执行时间
上述例子中LINQ语句是在foreach语句时才真正执行的,定义时只是定义了查询语句,在进入foreach枚举时才真正执行查询语句。如果我们在定义时需要立即返回查询结果可以使用ToArray或ToList方法(这两个方法也是在.Net Fromework 3.5中为IEnumerable接口新增的扩展方法)。
- Linq入门
- Linq 入门
- Linq 入门
- LINQ入门
- LINQ(入门)
- LINQ入门
- Linq入门
- Linq入门
- Linq入门
- LINQ入门
- LINQ 学习之入门
- LINQ查询入门(一)
- LINQ查询入门(二)
- C# 中的 LINQ 入门
- linq to xml入门
- C# 中的 LINQ 入门
- Linq入门系列教程
- Visual Basic LINQ入门
- 几个比较老的flash开源项目
- 使用phpExcel类导出excel文件相关问题总结
- EJB-Application roles:(应用角色)
- hack文章收藏
- JavaScript调用OCX函数()/含参 【转】
- LINQ(入门)
- grant select 遇到的问题
- sortable的基本用法和属性
- Linq(筛选与排序)
- myeclipse中导入.war文件
- vim 帮助文档
- lvextend 扩展逻辑卷大小
- 针对 SQL Server 2008 的访问配置 Windows 防火墙
- linux驱动之gpio3