[C#] IEnumerable vs IQueryable

这篇博客将介绍IEnumerable和IQueryable之间的区别。

1. IQueryable是继承自IEnumerable接口的。所以IEnumerable能做的,IQueryable都能做。

2. 先看代码,然后再讲两者之间的区别。

    using (NerdDinnerDataContext context =
        new NerdDinnerDataContext())
    {
        IEnumerable<Dinner> dinners = context.Dinners;

        IEnumerable<Dinner> filters = dinners.Where(d => d.DinnerID > 0).ToList();
    }

这段代码是去查询并找出DinnerID>0的所有Dinner。通过SQL Server Profiler可以看出,Where后面的过滤并没有在SQL中执行,而是将所有的Dinner集合返回到Client端,然后再进行Filter操作的。

下面将IEnumerable替换成IQueryable

    using (NerdDinnerDataContext context =
        new NerdDinnerDataContext())
    {
        IQueryable<Dinner> dinners = context.Dinners;

        IEnumerable<Dinner> filters = dinners.Where(d => d.DinnerID > 0).ToList();
    }

通过SQL Server Profiler可以看到,数据集的过滤是在DB一层执行的。

IQueryable与IEnumerable的区别在于前者的filter逻辑在DB端执行,后者的filter逻辑在Client端执行。

结论:

如果数据集合均为内存数据,建议使用IEnumerable。

如果数据是从数据库中获取,建议使用IQueryable,这样可以降低网络流量和充分利用SQL Server的处理能力。

感谢您的阅读~

时间: 2024-11-06 10:01:27

[C#] IEnumerable vs IQueryable的相关文章

Entity Framework返回IEnumerable还是IQueryable?

在使用EF的过程中,我们常常使用repository模式,本文就在repository层的返回值是IEnumerable类型还是IQueryable进行探讨. 阅读目录: 一.什么是Repository模式? 二.IEnumerable还是IQueryable的区别 三.实际检验IEnumerable和IQueryable的效率差别 四.总结 一, 什么是Repository模式? Repository是隔离在数据访问层和业务逻辑层之间的.它提供业务逻辑各种对象,使得业务逻辑代码不需要关心数据是

一个简单问题引发对IEnumerable和IQueryable的思考

问题概述:    首先看下图,有客户表和客户负责人表关系是多对多,访问数据库使用的是EF所以这里我们开启了延迟加载,需求就是将每个客户的所有负责人逗号拼接显示在负责人这一栏位, 对你没看错需求就是这么简单如果是写sql也许我们会去用两个循环去做,问题是要用linq实现. 这是我起初的写法: 首先申明这个resultlist接收到的类型本该是Iqueryable<Customer> 但我们要放入PrincipalNames字段(逗号拼接显示字段)所以接收的是匿名类型 这样写报的错是: 大概意思:

IEnumerable和IQueryable的区别以及背后的ExpressionTree表达式树

关于IEnumerable和IQueryable的区别,这事还要从泛型委托Func<T>说起.来看一个简单的泛型委托例子: class Program { static void Main(string[] args) { Func<int, bool> f = i => i > 5; Console.WriteLine(f(3)); Console.WriteLine(f(10)); Console.ReadKey(); } } Func<T>是"

IEnumerable和IQueryable和Linq的查询

IEnumerable和IEnumerable 1.IEnumerable查询必须在本地执行.并且执行查询前我们必须把所有的数据加载到本地.而且更多的时候.加载的数据有大量的数据是我们不需要的无效数据.但是我们却不得不传输更多的数据.做更多的无用功.使用IEnumerable,所有对于IEnumerable的过滤,排序等操作,都是在内存中发生的.也就是说数据已经从数据库中获取到了内存中,只是在内存中进行过滤和排序操作. 2.IQueryable却总能只提供你所需要的数据.大大减少了数据的传输IQ

IEnumerable和IQueryable区别、优缺点

转自 http://www.cnblogs.com/fly_dragon/archive/2011/02/21/1959933.html IEnumerable接口 公开枚举器,该枚举器支持在指定类型的集合上进行简单迭代.也就是说:实现了此接口的object,就可以直接使用foreach遍历此object: IQueryable 接口 它继承 IEnumerable 接口,而因为.net版本加入Linq和IQueryable后,使得IEnumerable不再那么单调,变得更加强大和丰富. 为了区

EntityFramework IEnumerable,IQueryable ,Include

使用IQueryable using (var db = new CentaStaffEntities()) { IQueryable<Staff> queryablestaffs = db.Staff.AsQueryable().OrderBy(p=>p.StaffID).Skip(3).Take(3); foreach (var item in queryablestaffs) { Console.WriteLine(item.CnName); } } 使用IEnumerable u

IEnumerable 和 IQueryable

共有两组 LINQ 标准查询运算符,一组在类型为 IEnumerable<T> 的对象上运行,另一组在类型为 IQueryable<T> 的对象上运行.构成每组运算符的方法分别是 Enumerable 和 Queryable 类的静态成员.这些方法被定义为作为方法运行目标的类型的"扩展方法".这意味着可以使用静态方法语法或实例方法语法来调用它们. 大家应该还记得,上节我们说过linq查询要执行在clr上师把查询语句变成扩展方法来执行,这两套东西不仅返回类型不同连

Linq查询IEnumerable与IQueryable

class Program { static void Main(string[] args) { System.Diagnostics.Stopwatch stp = new Stopwatch(); stp.Start(); DBCommonContext db = new DBCommonContext(); var usser_First = db.tbUsers.Where(p => p.UserID > 0);//.AsEnumerable(); var users_Now = u

最全数据结构详述: List VS IEnumerable VS IQueryable VS ICo

本文对常用的数据结构详述:Array, ArrayList,List,IList,ICollection, Stack, Queue, HashTable, Dictionary, IQueryable, IEnumerable. Collection(集合) Collection是数据记录集合, 编写代码过程中,常常需要合适的容器保存临时数据,方便修改和查找,如何选取合适的数据容器,关键在于将执行的数据操作以及数据记录是否大量. Array(数组) 特征 1. 固定大小,数组的大小是初始化时决