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