【发布时间】:2009-02-25 15:07:57
【问题描述】:
我想编写一个优雅的 linq 查询来处理以下 SAMPLE 对象模型:
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()!:
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();
有没有更好的方法来做到这一点?忽略我们不是在处理数据库并且 PK/FK 没有发挥作用的事实。
当我可以在 linq 查询中做同样的事情时,我真的想避免编写大的 for 循环:
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;
}
}
}
}
}
实际实现比这个简单的对象模型更复杂。我想从这个简单的示例中获得基本概念,因此我将其应用到我的真实对象模型中。
干杯!
【问题讨论】:
标签: c# linq linq-to-objects