C# 中的 IEnumerable 与 IQueryable 有什么区别?
- IEnumerable 存在于 System.Collections 名称空间中。
- IQueryable 存在于 System. Linq 名称空间中。
- IEnumerable 和 IQueryable 都是前向集合。
- IEnumerable 不支持延迟加载
- IQueryable 支持延迟加载
- 从数据库中查询数据时,IEnumerable 会在服务器端执行选择查询,在客户端载入内存数据,然后过滤数据。
- 从数据库中查询数据时,IQueryable 使用所有过滤器在服务器端执行选择查询。
- IEnumerable 扩展方法采用可操作对象。
- IQueryable 扩展方法采用表达式对象,即表达式树。
示例
IEnumerable
dbContext dc = new dbContext ();
IEnumerable
<SocialMedia>
list = dc.SocialMedias.Where(p => p.Name.StartsWith("T"));
list = list.Take<SocialMedia>(1);
</SocialMedia>为上述查询生成的 SQL 语句
SELECT [t0].[ID], [t0].[Name] FROM [SocialMedia] AS [t0] WHERE [t0].[Name] LIKE @p0
IQueryable
dbContext dc = new dbContext ();
IQueryable<SocialMedia> list = dc.SocialMedias.Where(p => p.Name.StartsWith("T"));
list = list.Take<SocialMedia>(1);为上述查询生成的 SQL 语句
SELECT top 1 [t0].[ID], [t0].[Name] FROM [SocialMedia] AS [t0] WHERE [t0].[Name] LIKE @p0
广告
数据结构
网络
关系型数据库管理系统(RDBMS)
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP