1

假设我有以下课程:

public class Parent
{
   public string name;
   IList<Child> children;
}

public class Child
{
  public string parentName;
  public int age;
}

可以理解,每个父母可以有多个孩子,我们也可以有多个父母。初始化这些类的最佳方法是什么?从数据库中获取所有父母和所有孩子然后使用LINQ会更好吗?

IList<Parent> parents = GetParents() //assume this gets parents from db
IList<Child> children = GetChildren() //assume this gets children from db
foreach(Parent parent in parents)
{
   parent.children = children.Where(x=>x.parentName == parent.name).ToList();
}

还是获取所有父母并遍历每个父母以通过parentName查询数据库以获取孩子信息?由于我的要求,我不能使用数据表或数据集;我只能使用数据阅读器。

IList<Parent> parents = GetParents()//assume this gets parents from db
foreach(Parent parent in parents)
{
  parent.children = GetChildrenByParentName();//assume this gets parents from db by parentName
}

谢谢

4

2 回答 2

2

如果您无法利用 LinqToSql、Entity Framework 或其他一些自定义查询方法,并且您必须按照您建议的庄园将所有父母及其子女加载到数据库中,那么您的第一个选项很可能更优越。假设您将查询两个表的所有行,第一个选项将只导致两个数据库查询。在第二个选项中,您将拥有与孩子数量一样多的查询以及对父母的查询。

编辑

此外,特别是在数据集很大的情况下,您可以使用Enumerable.ToLookup获得进一步的性能。这实质上为您创建了一个排序字典,这使得搜索适当的孩子更加有效,因为框架可以使用二进制搜索。您可以按如下方式使用它:

var children = GetChildren().ToLookup(p => p.parentName);

...然后在您的循环中...

parent.children = children[parent.name].ToList();
于 2013-10-24T22:10:09.677 回答
0

我认为如果父母和孩子有基本字段,你应该在数据库中有一个表,并且有一个额外的属性Parent,它引用同一个表行,(所以它指向它在数据库中的父级)你可以确定,如果该行是子元素或父元素,如果它Parent不为空,那么它应该是行的子元素Parent

于 2013-11-11T15:20:46.347 回答