In LINQ the query execution has two behavior one is
Deferred and another one is
Immediate. Deferred is nothing but delayed execution of query whereas immediate execution will execute the script instantly.
Deferred Execution
Consider this example below (Again our same old example which we are dealing in the whole series)
Our custom class type (Student)
List of Students
Let’s add one more student after querying the
students collection (and ordering them to descending) and see what the result will look while iterating the result as shown below
As you can see above, I am adding a student named Jacob after querying the students collection
Output
Now you might wonder, how this has happened, since we added Jacob only after query execution, where the descending order operation might have already taken place, but still how come the students are correctly ordered based on their StudID, the
answer is
Deferred Execution behavior of LINQ.
Since the execution of LINQ query does not takes place while you do the query, but the actual execution happens while you do Iteration. Hence deferred execution can be better described as
“LINQ Query execution happens only during iteration, rather during query declaration, this execution behavior of LINQ is called as Deferred Execution”
As you can see below, instead of 5 records, LINQ query initially taken 6 (Adding the new value)
Immediate Execution
Here we are going to convert our query to List (remember we already discussed about ToList in
Conversion methods in LINQ)
Hence our code looks like this
But let’s see what the output
Well wait, what happened to Jacob, do you see the newly added student here,
NO. We will see what happened to our student behind the scene by debugging the code.
As you can see from the above code execution, the StudM implicitly typed variable type has got only 5 records, but in the Deferred execution we had 6 records and that’s the reason we couldn’t see our newly added record (Jacob) in immediate execution, whereas the opposite happened in deferred execution.
Purpose
Okay, I got what you are thinking, why do LINQ really has this behavior right?
Well, you spot it right.
Consider the situation where you might need to store thousand users detail in a list of users collection and you know that only these users will be there for the rest of your code execution while you manipulate them, then instead of having deferred execution, where your LINQ query will every time query the SQL Database for every record during every single iteration, you can use Immediate execution, where it query database only once and store all the details and convert them to List (As done above). This will tremendously increase your performance.
But Deferred execution come handy while your data is dynamic and while you need to get the up-to-date data.
I hope this article in LINQ series might have given you a complete understanding of the LINQ execution behavior.
Please leave your comments and thanks for reading !!
Thanks,
Karthik KK
Nice