如何在一个模型中指定父子关系?

时间:2018-01-15 11:57:25

标签: python django relationship

例如,我有以下代码:

class FamilyMember(models.Model):
    user = models.OneToOneField(User)

我有以下情况:

a1 = FamilyMember.objects.get(id=1)
a1.first_name = 'John'
a1.last_name = 'Smith'
(a1 is a parent of a2)

a2 = FamilyMember.objects.get(id=2)
a2.first_name = 'Mark'
a2.last_name = 'Smith'
(a2 is a child of a1 and parent of a3 in the same time)

a3 = FamilyMember.objects.get(id=3)
a3.first_name = 'Jason'
a3.last_name = 'Smith'
(a3 is a child of a2)

我如何在一个模型中实现这种关系?

2 个答案:

答案 0 :(得分:3)

您可以使用简单的ForeignKey to self来指示父级:

parent = models.ForeignKey('self', blank=True, null=True, related_name='children')

现在您可以执行a2.parent = a1,并会自动获得对a1.children.all()的访问权限。

答案 1 :(得分:3)

您可以将父FamilyMember存储在每个FamilyMember实例中,如下所示:

class FamilyMember(models.Model):
    user = models.OneToOneField(User)
    parent = models.ForeignKey('self', null=True)

这样每个FamilyMember都有一个父级,但可以是多个FamilyMember个实例的父级。另外,为简单起见,我将父字段设为可为空。

要保存您可以执行的数据:

user_a1 = User(user_a1_data)
user_a1.save()
a1 = FamilyMember(user=user_a1, parent=None)
a1.save()

user_a2 = User(user_a2_data)
user_a2.save()
a2 = FamilyMember(user=user_a2, parent=a1)
a2.save()

同样适用于a3等等。

注意user_a1_datauser_a2_data必须是用户first_namelast_name和其他字段。这是不是必须在这里输入所有字段。

要检索您可以执行的数据:

a2 = FamilyMember.objects.get(pk=1)  # Assuming pk 1 is from a1.
a2_parent = a2.parent  # That'd be a1.
a2_parent.user.first_name # This it a1's name. Don't forget the '.user'.

注意:这是未经测试的示例代码,只是为了帮助您了解如何组织模型关系。这里的意图不是复制/粘贴就绪解决方案。

您可以调整此示例来代替或替代父项或

来存储子项