Я хочу, чтобы написать элегантный запрос Linq для обработки следующего объекта ОБРАЗЦА модели:Linq запрос с агрегатами
class Category
{
public string Name { get; set; }
public IList<Product> Products { get; set;}
}
class Product
{
public string Title { get; set; }
public IList<Photo> Photos { get; set; }
}
class Photo
{
public int Id { get; set; }
}
я построил следующий запрос, чтобы получить фото Id:
var query = from category in Factory.GetCategories()
where category.Name == "Cameras"
select (from product in category.Products
where product.Title == "Sony"
select (from photo in product.Photos
select photo.Id)
);
var v = query.ToList();
На момент запроса не проецировать правильно я должен добавить FirstOrDefault() для каждого из подкомитетов Selects !:
var query = from category in Factory.GetCategories()
where category.Name == "Cameras"
select (from product in category.Products
where product.Title == "Sony"
select (from photo in product.Photos
select photo.Id).FirstOrDefault()
).FirstOrDefault();
var v = query.ToList();
Есть ли лучший способ сделать это? Игнорируя тот факт, что мы не имеем дело с базой данных и ПК/FK, не играют.
Я действительно хочу, чтобы не писать большой цикл, когда я мог бы сделать то же самое в запросе Linq:
foreach (var category in Factory.GetCategories())
{
if (category.Name == "Camera")
{
foreach (var product in category.Products)
{
if (product.Title == "Sony")
{
foreach (var photo in product.Photos)
{
//get data
int id = photo.Id;
}
}
}
}
}
Фактическая реализация является более сложной, чем это простой объектной модели. Я хочу получить основную идею из этого простого примера, поэтому я применил его к моей реальной объектной модели.
Cheers!
Cheers Marc, я думаю, вы и Джон предоставили тот же ответ :). Гораздо больше elgant, чем я первоначально начал с. – 2009-02-25 15:25:05