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

更新于:2020 年 8 月 5 日

10K+ 浏览量

开启你的 职业生涯

完成该课程并获得认证

开始学习
广告