Подзапрос в LINQ, который находится в операторе select, а не в предложении where - PullRequest
5 голосов
/ 20 января 2010

Мне нужно сделать что-то вроде следующего

SELECT p.name, 
   (SELECT COUNT(p.id) FROM products WHERE products.parent_id = p.id) AS sub_products
FROM products AS p

Я вижу много примеров LINQ подзапросов в предложении where, но ничего подобного в выражении select.

1 Ответ

3 голосов
/ 20 января 2010

Этот запрос должен быть эквивалентен:

var query = Products.Select(p => new {
                         p.Name,
                         SubProducts = Products.Count(c => c.parent_id == p.id)
                     });

foreach (var item in query)
{
    Console.WriteLine("{0} : {1}", item.Name, item.SubProducts);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...