我有一个像这样的对象模型
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
ControllerCode
[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 };
}
我正在尝试避免使用ToList(),因为我不希望返回所有父记录。 ViewModel将使用Ajax绑定到Telerik Grid,这将处理分页。 我不想使用AutoMapper,因为我不希望返回所有字段和记录。
如何在不使用ToList()的情况下展平此模型?
答案 0 :(得分:0)
使用
Sibling = p.Sibling == null ? null : new ViewModelSibling(...)
或
Sibling = new ViewModelSibling{ Id = p.Sibling == null ? 0 : p.Sibling.Id, etc ... }
取决于您的要求。
等...