When working with a database, sometimes the situation may become confusing. Some questions may develop such as what we should use to fetch data from SQL Server, should I go with IEnumerable or should I go with IQueryable?
So here I am trying to show the difference between these two and you can use them depending on your requirements.
IEnumerable
So here I am trying to show the difference between these two and you can use them depending on your requirements.
IEnumerable
- System.Collection namespace
- No Base Interface
- Supports Deferred Execution
- No Lazy Loading
- No Custom Query support
- Suitable for LINQ to Object and LINQ to XML Queries
- When querying data from a database IEnumerable executes a SELECT query on the server side. It loads the data in-memory on the client side and does a filter.
Now we will see how IEnumerable works in real life.
I have a Table Employee in my database as in the following:
data:image/s3,"s3://crabby-images/d99f9/d99f99fda285ccb4dc1ff3d5ec24658ad894094c" alt="Table Employee"
Figure 1: Employee table
Now I created a new application and right-click on the solution then select Add New Item -> LINQ To SQL Classes -> Employee.dbml.
Now write your query to select records from the Employee Table as in the following:
data:image/s3,"s3://crabby-images/e6da4/e6da46efb0c78089927f00c5c25bea6c8f0ce2ce" alt="Table"
Figure 2: Selecting records from Employee table
I have a Table Employee in my database as in the following:
data:image/s3,"s3://crabby-images/46ca0/46ca03007045d20d622159e6ff62a84818efacd7" alt="Table Employee"
Figure 1: Employee table
Now I created a new application and right-click on the solution then select Add New Item -> LINQ To SQL Classes -> Employee.dbml.
Now write your query to select records from the Employee Table as in the following:
data:image/s3,"s3://crabby-images/31778/317788959729f282bbf09461cf8debb4eeacc38c" alt="Table"
Figure 2: Selecting records from Employee table
- EmployeeDataContext dc = new EmployeeDataContext();
- IEnumerable<Employee> list = dc.Employees.Where(p => p.Name.StartsWith("S"));
- list = list.Take<Employee>(10);
data:image/s3,"s3://crabby-images/e7308/e73085f42adb47d0581e0c225f51149a779967c8" alt="Debug"
Figure 3: After debugging
The following is the SQL Query corresponding to the preceding statement:
- SELECT [t0].[ID], [t0].[Name], [t0].[Email], [t0].[Country]
- FROM [dbo].[Employee] AS [t0]
- WHERE [t0].[Name] LIKE @p0
IQueryable
- System.Linq namespace.
- Best to query data from Out-Memory.
- When querying data from a database IQueryable executes a SELECT Query on the server side with all filters.
- Suitable for LINQ To SQL Queries.
- Supports Deferred Execution.
- Supports custom query using Create Query and Execute methods.
- Supports Lazy Loading.
Now we will see it programmatically as in the following:
data:image/s3,"s3://crabby-images/04445/04445d4a42e531395199dd6156fa0d37f192aeee" alt="see it program"
Figure 4: Code Snippet
data:image/s3,"s3://crabby-images/9a66d/9a66d9dae08ca022a39548d60b1225219397b07f" alt="see it program"
Figure 4: Code Snippet
- EmployeeDataContext dc = new EmployeeDataContext();
- IQueryable<Employee> list = dc.Employees.Where(p => p.Name.StartsWith("S"));
- list = list.Take<Employee>(10
data:image/s3,"s3://crabby-images/9894b/9894bdd5b3e3ebfb92fc7a133735d68f16ee1614" alt="Now debug Query"
Figure 5: After debugging
- SELECT TOP (10) [t0].[ID], [t0].[Name], [t0].[Email], [t0].[Country]
- FROM [dbo].[Employee] AS [t0]
- WHERE [t0].[Name] LIKE @p0
data:image/s3,"s3://crabby-images/e4481/e4481270dd5d9eab1e5b421305fc03d3ba656bd4" alt="see the difference"
Image 6.
No comments:
Post a Comment