我知道有一种简单的方法可以做到这一点,但我的递归能力已经过时了。给定一个包含三个字段的数据库表:
id
label
child_id
我应该能够组合一个递归函数,它会给出如下输出:
child (input of program)
parent1
parent2
grandparent1
great-grandparent1
grandparent2
grandparent3
parent3
grandparent4
grandparent5
我知道这应该很容易,但我无法通过心理体操来让它发挥作用。另外,这是一件好事吗?似乎我最终可能会打开相当多的数据库连接。
我认为这是让我感到困难的部分。我从一个 child_id 开始,然后一路向上。一个孩子可以有很多父母。因此,输出将是树“根”处的子 ID,然后是每个分支的父母和祖父母。我越想,这只是传统的“一个父母,许多祖父母”的公式,除了语义。我可能只是想多了。
该表看起来像这样:
table parents
id child_id label
1 NULL child
2 1 parent1
3 1 parent2
4 1 parent3
5 3 grandparent1
6 3 grandparent2
7 3 grandparent3
8 5 great-grandparent1
9 4 grandparent4
10 4 grandparent5