Jump into concepts and practice - no test required
or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Recall & Review
beginner
What is the purpose of the Select clause in LINQ?
The Select clause is used to choose or transform elements from a collection into a new form or shape.
Click to reveal answer
beginner
How do you project only the names from a list of Person objects using LINQ?
You use Select(person => person.Name) to create a new collection of just the names.
Click to reveal answer
intermediate
What does this LINQ query do?
var result = people.Select(p => new { p.Name, p.Age });
It creates a new collection of anonymous objects, each containing only the Name and Age properties from each Person.
Click to reveal answer
intermediate
Can the Select clause be used to change the type of elements in the collection?
Yes, Select can transform elements into any type, including anonymous types, new classes, or simple values.
Click to reveal answer
beginner
What happens if you use Select without changing the element inside the lambda?
The query returns the original elements unchanged, effectively creating a copy of the collection.
Click to reveal answer
What does the Select clause do in a LINQ query?
ATransforms each element into a new form
BFilters elements based on a condition
CSorts elements in ascending order
DJoins two collections
✗ Incorrect
The Select clause projects each element into a new form or shape.
Which syntax correctly projects only the Age property from a list of Person objects named people?
Apeople.GroupBy(p => p.Age)
Bpeople.Where(p => p.Age)
Cpeople.OrderBy(p => p.Age)
Dpeople.Select(p => p.Age)
✗ Incorrect
Select is used to project or transform elements, so people.Select(p => p.Age) returns only ages.
What type of object is created by this query?
people.Select(p => new { p.Name, p.City })
AAnonymous type with Name and City
BList of strings
COriginal Person objects
DInteger values
✗ Incorrect
The query creates anonymous objects containing only the Name and City properties.
If you want to keep the original elements unchanged, what should your Select clause look like?
ASelect(p => new { p.Name })
BSelect(p => p.Name)
CSelect(p => p)
DSelect(p => p.Age)
✗ Incorrect
Using Select(p => p) returns the original elements without changes.
Can Select be used to create a list of a different type than the original collection?
ANo, it must keep the same type
BYes, it can transform elements into any type
COnly if the types are numeric
DOnly if the types are strings
✗ Incorrect
Select can transform elements into any type, including anonymous types or new classes.
Explain how the Select clause is used to transform data in a LINQ query.
Think about how you pick or change data from a list.
You got /4 concepts.
Describe the difference between using Select to return original elements and using it to create new anonymous types.
Consider when you want the same data or a new form of data.
You got /4 concepts.
Practice
(1/5)
1. What does the select clause do in a LINQ query in C#?
easy
A. It groups the data by a key.
B. It filters the data based on a condition.
C. It sorts the data in ascending order.
D. It chooses and shapes the data to return from the query.
Solution
Step 1: Understand the role of select in LINQ
The select clause defines what data to return from the query, shaping the output.
Step 2: Differentiate from other clauses
Filtering is done by where, sorting by orderby, grouping by group by. Only select shapes the output.
Final Answer:
It chooses and shapes the data to return from the query. -> Option D
Quick Check:
Select clause = shapes output [OK]
Hint: Select clause shapes output data, not filters or sorts [OK]
Common Mistakes:
Confusing select with where clause
Thinking select sorts data
Mixing select with group by
2. Which of the following is the correct syntax for a LINQ query using select to get only the names from a list of Person objects?
easy
A. var names = from p in people select p.Name;
B. var names = from p in people where p.Name;
C. var names = from p in people orderby p.Name select p;
D. var names = from p in people group p by p.Name;
Solution
Step 1: Identify correct select syntax
The correct syntax to project only the Name property is select p.Name.
Step 2: Check other options for errors
var names = from p in people where p.Name; uses where incorrectly without a condition. var names = from p in people orderby p.Name select p; selects whole object, not just names. var names = from p in people group p by p.Name; groups data, not selects.
Final Answer:
var names = from p in people select p.Name; -> Option A
Quick Check:
Select projects properties correctly [OK]
Hint: Select clause syntax: from x in y select x.Property [OK]
Common Mistakes:
Using where without condition
Selecting whole object instead of property
Confusing group by with select
3. What is the output of this code?
var numbers = new[] {1, 2, 3};
var result = from n in numbers select n * 2;
foreach(var r in result) Console.Write(r + " ");
medium
A. 1 2 3
B. 3 4 5
C. 2 4 6
D. Syntax error
Solution
Step 1: Understand the select projection
The query multiplies each number by 2, so 1 becomes 2, 2 becomes 4, 3 becomes 6.
Step 2: Trace the output loop
The foreach prints each doubled number followed by a space: "2 4 6 "
Final Answer:
2 4 6 -> Option C
Quick Check:
Select doubles numbers = 2 4 6 [OK]
Hint: Select transforms each item; multiply 1,2,3 by 2 = 2,4,6 [OK]
Common Mistakes:
Thinking select filters instead of transforms
Expecting original numbers
Confusing output format
4. Identify the error in this LINQ query:
var people = new List<Person>();
var names = from p in people select p.Name.ToUpper;
medium
A. select clause must come before from clause.
B. Missing parentheses after ToUpper method call.
C. List<Person> cannot be queried with LINQ.
D. Cannot select Name property directly.
Solution
Step 1: Check method usage in select
ToUpper is a method and requires parentheses: ToUpper().
Step 2: Validate other options
Cannot select Name property directly. is wrong because selecting Name is valid. List<Person> cannot be queried with LINQ. is wrong because List supports LINQ. select clause must come before from clause. is wrong because from must come first.
Final Answer:
Missing parentheses after ToUpper method call. -> Option B
Quick Check:
Method calls need () [OK]
Hint: Method calls need parentheses, e.g., ToUpper() [OK]
Common Mistakes:
Forgetting () after method names
Misordering LINQ clauses
Thinking List can't use LINQ
5. Given a list of products with properties Name and Price, how would you use a LINQ select clause to create a new list of anonymous objects containing only Name and a discounted price (10% off)?
hard
A. var discounted = from p in products select new { p.Name, DiscountedPrice = p.Price * 0.9 };
B. var discounted = from p in products select p.Name, p.Price * 0.9;
C. var discounted = from p in products where p.Price > 0.9 select p.Name;
D. var discounted = from p in products select new List { p.Name, p.Price * 0.9 };
Solution
Step 1: Understand anonymous object creation in select
To create new shaped data, use new { } with property assignments inside select.
Step 2: Check each option's correctness
var discounted = from p in products select new { p.Name, DiscountedPrice = p.Price * 0.9 }; correctly creates anonymous objects with Name and discounted price. var discounted = from p in products select p.Name, p.Price * 0.9; syntax is invalid (multiple values without new). var discounted = from p in products where p.Price > 0.9 select p.Name; filters but does not create discounted price. var discounted = from p in products select new List { p.Name, p.Price * 0.9 }; tries to create a List incorrectly.
Final Answer:
var discounted = from p in products select new { p.Name, DiscountedPrice = p.Price * 0.9 }; -> Option A
Quick Check:
Select new anonymous objects with discounted price [OK]
Hint: Use new { } in select to create shaped objects [OK]