IQueryable与IQEnumberable的区别
IEnumberable接口:
公开枚举器,该枚举器支持在指定类型的集合上进行简单迭代。也就是说:实现了此接口的object,就可以直接使用froeach遍历此object;
IQueryable接口:
它继承IEnumerable接口,而因为.net版本加Linq和IQueryable后,使得IEnumberable不再那么单调,变得更加强大和丰富。为了区别这两个接口,我们通过一个例子来解释一下。
编写的代码如下:
static void Main(string[] args)
{
//创建数据库访问接口
using (HotalDataBaseEntities hotalEntities = new HotalDataBaseEntities())
{
//查询的结果放入IQueryable接口的集合中
IQueryable<Room> roomIQue = (from c in hotalEntities.Room
orderby c.RoomNum
select c).Skip<Room>().Take<Room>();
//注意在这个AsEnumerable<Room>()在分页查询之前,先将其转换成IEnumerable类型
IEnumerable<Room> roomIEnu = (from c in hotalEntities.Room
orderby c.RoomNum
select c).AsEnumerable<Room>().Skip<Room>().Take<Room>();
//因为启用了延迟加载机制,所惟下面调用一下,才会真正去读取数据库
int i = ;
foreach (var c in roomIQue)
{
i++;
}
Console.WriteLine(i);
foreach (var c in roomIEnu)
{
i++;
}
Console.WriteLine(i);
}
Console.WriteLine("运行完毕");
Console.ReadKey(); }
注意红色代码部分,在用Linq查询实体集合之前我先将其转换成IEnumerable接口类型,看看最终执行sql是怎样的。
第一种:直接返回IQueryable类型的查询,如下图所示:
第二种:在用分页查询之前先将其转换成IEnumerable实际执行的sql如下图所示:

总结:
IQueryable接口与IEnumberable接口的区别:IEnumerable<T>泛型类在调用自己的Skip和Take等扩展方法之前数据就已经加载到本地内存里面,而IQueryable<T>是将Skip,Take这些方表达式翻译成T_sql语句之后再向Sql服务器发送命令,它并不是把所有的数据都加载到内存里来才进行条件过滤。
IQueryable与IQEnumberable的区别的更多相关文章
- C#中IQueryable和IEnumberable的区别
		IQueryable和IEnumberable的区别主要在查询方面有区别 IQueryable查询时间是先把skip和Take翻译成sql语句,去数据库执行完成后把数据加载到内存中 IEnumbera ... 
- EF入门  IQueryable和IEnumberable的区别
		IEnumerable接口 公开枚举器,该枚举器支持在指定类型的集合上进行简单迭代.也就是说:实现了此接口的object,就可以直接使用foreach遍历此object: IQueryable 接口 ... 
- Entity Framework中IQueryable, IEnumerable, IList的区别(转载)
		原文:http://www.cnblogs.com/hiteddy/archive/2011/10/01/Difference_among_IQueryable_IEnumeralb_IList_in ... 
- C#编程之IList<T>、List<T>、ArrayList、IList, ICollection、IEnumerable、IEnumerator、IQueryable 和 IEnumerable的区别
		额...今天看了半天Ilist<T>和List<T>的区别,然后惊奇的发现使用IList<T>还是List<T>对我的项目来说没有区别... 在C#中 ... 
- Entity Framework中IQueryable, IEnumerable, IList的区别[转]
		使用工具追踪EF生成的SQL 使用Entity Framework等ORM框架的时候,SQL对于使用者来说是透明的,往往很多人也不关心ORM所生成的SQL,然而系统出现性能问题的时候就必须关注生成的S ... 
- C#中IQueryable和IEnumerable的区别
		最近的一个面试中,被问到IQueryable 和 IEnumerable的区别, 我自己看了一些文章,总结如下: 1. 要明白一点,IQueryable接口是继承自IEnumerable的接口的. 2 ... 
- Linq之IQueryable接口与IEnumberable区别
		IEnumerable接口 公开枚举器,该枚举器支持在指定类型的集合上进行简单迭代.也就是说:实现了此接口的object,就可以直接使用foreach遍历此object: IEnumerable 包含 ... 
- IQueryable与IEnumberable的区别
		IEnumerable接口 公开枚举器,该枚举器支持在指定类型的集合上进行简单迭代.也就是说:实现了此接口的object,就可以直接使用foreach遍历此object: IQueryable 接口 ... 
- IQueryable接口与IEnumberable区别
		IEnumerable<T> 泛型类在调用自己的SKip 和 Take 等扩展方法之前数据就已经加载在本地内存里了,而IQueryable<T> 是将Skip ,take 这些 ... 
随机推荐
- JS匿名函数&闭包
			<html> <head> <title> test </title> </head> <body> <script ty ... 
- Python installation
			PIP:Python & OS Support pip works with CPython versions 2.6, 2.7, 3.2, 3.3, 3.4 and also pypy. p ... 
- sql小总结
			---------------------------------------------------------------------------------------------------- ... 
- requestWindowFeature()应用
			我们在开发程序是常常会须要软件全屏显示.自己定义标题(使用button等控件)和其它的需求,今天这一讲就是怎样控制Android应用程序的窗口显示. 首先介绍一个重要方法那就是requestWindo ... 
- RTP 记录 log 该机制
			我们 RCV 在这里,经常跑concurrent request RTP: Receiving Transaction Processor, 它主要是用来处理 RCV_TRANSACTIONS_INT ... 
- (Chrome42)Lodop总计页面提示“未安装”要么“请升级”可能的原因和解决方案
			Chrome42版本号之后,支持NP态,要手工打开,方法例如以下: 在谷歌浏览器地址栏输入: chrome://flags/#enable-npapi 然后找到"启用NPAPI"地 ... 
- gets、scanf和getchar之间的区别
			gets gets.scanf和getchar之间的区别 1. gets函数读取数据时,接受的数据包括数据和回车符.即:读取数据后输入流没有输入 操作动作. 2. scanf函数读取数据时,接受的数据 ... 
- linux_shell_获取日期相关
			shell里直接调用系统变量 获取当天日期`date +%Y%m%d` 获取昨天日期`date -d yesterday +%Y%m%d` 获取前天日期`date -d -2day +%Y%m%d` ... 
- MAC使用小技巧(二)
			一.Safari-->广告数量不足 --原因:DNS被拦截,被恶意推送广告. ----------------------------- [ 思路 ] 修改hosts文件 $ cd /etc $ ... 
- ArcEngine载入中SDE问题栅格数据
			当直接加载矢量数据到IFeatureWorkspace接口可,但是,在装载门格当要传送的数据IRasterWorkspaceEx接口. 效果如下面的,对可以被添加到双击Globe在. watermar ... 
