私はこのようなオブジェクトモデルを持っています
public class Parent{
public int Id;
public string Name;
public Child Sibling
}
public class Sibling {
public int Id;
public string Name;
public Cousin Cousin
}
public class Cousin{
public int Id;
public string Name;
public DateTime CreatedDate;
}
フラット化または投影しようとしていますか? このようなモデルに
public class ViewModelSibling {
public int Id;
public string Name;
}
public class ViewModel{
public int ParentId;
public string ParentName;
public ViewModelSibling Sibling;
public ViewModelSibling Cousin;
public DateTime? CousinCreatedDate;
}
Sibling と Cousin は Nullable です
コントローラーコード
[HttpPost]
public virtual ActionResult GetGridItems()
{
IQueryable<Parent> parents = GetParentsWhereCriteriaMet();
var data = parents.Select( p => new ViewModel{
ParentId = p.Id,
ParentName = p.Name,
Sibling = new ViewModelSibling { Id = p.Sibling.Id, Name = p.Sibling.Name},// if p.Sibling is null and exception is thrown
Cousin= new ViewModelSibling {Id =p.Sibling.Cousin.Id, Name = p.Sibling.Cousin.Name}// if p.Sibling or p.Sibling.Cousin are null and exception is thrown
CousinCreatedDate = p.Sibling.Cousin.CreatedDate
} )
return new JsonResult { Data = data };
}
すべての Parent レコードを返したくないので、ToList() の使用を避けようとしています。ViewModel は、Ajax を使用して Telerik Grid にバインドされます。これにより、ページングが処理されます。すべてのフィールドとレコードを返したくないので、AutoMapper を使用したくありません。
ToList() を使用せずにこのモデルを平坦化するにはどうすればよいですか?