次の SAMPLE オブジェクト モデルを処理するエレガントな 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();
現時点では、クエリが正しく投影されません。各 Sub Selects に 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;
}
}
}
}
}
実際の実装は、この単純なオブジェクト モデルよりも複雑です。この単純なサンプルから基本的なアイデアを得たいので、実際のオブジェクト モデルに適用します。
乾杯!