通常、次の例のように、これらの 1 対多のクエリを自分でマップします。
[TableName("Blogs"), PrimaryKey("BlogId")]
public class Blog {
public int BlogId {get;set;}
public string Title {get;set;}
[Ignore]
public IList<Post> Posts {get;set;}
}
[TableName("Posts"), PrimaryKey("PostId")]
public class Post {
public int PostId {get;set;}
public int BlogId {get;set;}
public string Subject {get;set;}
public string Content {get;set;}
}
public class FlatBlogPost {
public int BlogId {get;set;}
public string Title {get;set;}
public int PostId {get;set;}
public string Subject {get;set;}
public string Content {get;set;}
}
1 つのブログの投稿のリストを表示する方法と、あまり手間をかけずにすべてのブログを表示する方法は 2 つあります。
1.2 つのクエリ -
var Blog = Db.Query<Blog>(1);
var Posts = Db.Query<Post>("where BlogId = @0", 1);
2.1 つのクエリ =
var flat = Db.Query<FlatBlogPost>("select b.blogid, b.title, p.postid, p.subject,
p.content from blogs b inner join posts p on b.blogid = p.blogid where
b.blogid = @0", 1);
var blog = flat
.GroupBy(x=> new { x.BlogId, x.Title })
.Select(x=> new Blog {
BlogId = x.Key.BlogId,
Title = x.Key.Title,
Posts = x.Select(y=> new Post{
PostId = y.PostId,
BlogId = x.Key.BlogId,
Subject = y.Subject,
Content = y.Content
}).ToList()
});
ただし、通常、番号 2 では、FlatBlogPost オブジェクトから、データを表示する必要があるビューモデルに直接マップします。
更新
PetaPoco を拡張して基本的な 1 対多および多対 1 クエリをサポートするこれらのヘルパーを確認してください。https://schotime.wordpress.com/2011/08/21/petapoco- _一対多および多対一/