Sign in to track progress and bookmarks.
Every LINQ query begins and ends with Where (Filtering) and Select (Projection). Mastery of these two ensures your data stays lean and relevant.
Filters a sequence based on a predicate. **Architect Tip:** Always filter as early as possible in your pipeline (especially in IQueryable) to reduce the amount of data being processed in subsequent steps.
Transforms each element into a new form. This is where you create **Anonymous Types** or **DTOs**. Never pull a whole User entity from the DB if you only need the Email.
// Projecting to a DTO (Data Transfer Object)
var userEmails = _db.Users
.Where(u => u.IsActive)
.Select(u => new UserDto {
Email = u.Email,
FullName = u.FirstName + " " + u.LastName
});
Q: "Should I use the index overload of Select?"
Architect Answer: "Yes! Both Where and Select have overloads that provide the **Index** of the current element: .Select((item, index) => ...). This is incredibly useful for UI logic, like zebra-striping rows or generating unique IDs based on list position, without having to maintain an external counter variable."
Quizzes linked to this course—pass to earn certificates.
On this page
1. The 'Where' Clause 2. The 'Select' Clause (Projection) 3. Architect Insight