2011-11-22 42 views
1

的名单上有一些模型设置如下:列表转换成家长带着孩子

public class Form 
{ 
    public int FormId { get; set; } 
    public virtual ICollection<SubForm> SubForms{ get; set; } 
} 
public class SubForm 
{ 
    public int SubFormId { get; set; } 
    public virtual Form Form {get; set;} 
} 

我有一个这样的名单:

List<SubForm> subForms; <-- already populated, each subform has a form parent. 

我如何得到它像这样的最佳(拉姆达优选的)的格式

List<Form> formsWithChildren; 
+0

'subForms.Select(i => i.Form).Distinct()',也许? – Joe

回答

0

您可以将通过FormId然后分配分组子窗体到每个新Form项目如下:

var formsWithChildren = subForms.GroupBy(s => s.Form.FormId) 
           .Select(g => new Form 
           { 
            FormId = g.Key, 
            SubForms = g.ToList() 
           }).ToList(); 

编辑:如果其他属性存在,那么您将不得不将它们映射到对象初始值设定项中,但这可能会变得单调乏味,如果您打算在其他场景中重复使用这种类型的查询,则不是最佳选择。我建议创建一个新的Form对象并使用AutoMapper进行映射。

如果你决定使用AutoMapper的办法是与此类似:

var formsWithChildren = new List<Form>(); 
foreach (var item in subForms.GroupBy(s => s.Form)) 
{ 
    Form f = Mapper.Map<Form, Form>(item.Key); 
    f.SubForms = item.Select(s => s).ToList(); 
    formsWithChildren.Add(f); 
} 

要了解更多信息请参考AutoMapper site

或者,您可以采取如下方法,虽然这会修改现有的项目,所以要注意这一点。

var formsWithChildren = new List<Form>(); 
foreach (var item in subForms.GroupBy(s => s.Form)) 
{ 
    // re-use existing Form from grouping so it retains its assigned values 
    Form f = item.Key; 
    f.SubForms = item.Select(s => s).ToList(); 
    formsWithChildren.Add(f); 
} 

在你上面所示的两种方法都需要在Form类实现Equals以GROUPBY的的Form代替FormId

public class Form 
{ 
    public int FormId { get; set; } 
    public virtual ICollection<SubForm> SubForms{ get; set; } 

    public override bool Equals(object obj) 
    { 
     if (obj == null) 
      return false; 

     Form f = obj as Form;    
     return this.Equals(f); 
    } 

    public bool Equals(Form f) 
    { 
     if (f == null) 
      return false; 

     return this.FormId == f.FormId; 
    } 

    public override int GetHashCode() 
    { 
     return this.FormId.GetHashCode(); 
    } 
} 

你可以扩展平等和GetHashCode方法使用属性来确定唯一性。目前它只依靠FormId

+0

如果'Form'中还有其他属性呢?他们不会被复制 –

+0

@Lolcoder看到我的更新。 –

1
formsWithChildren = subForms.Select(x => x.Form).Distinct().ToList(); 

这是你的意思吗?而无需创建新的表单对象

+0

这会把相关的子表单放在每个表单下吗? –

+0

@Lolcoder:你是什么意思? – Ryan

0

方法:

 //Populate subForms list of the forms 
     subForms.GroupBy(x => x.Form).ForEach(x => x.Key.SubForms = x.ToList()); 
     //Select forms 
     var forms = subForms.Select(x => x.Form).Distinct().ToList();