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
广告