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

问题描述 投票:1回答:2

例如,我有以下代码:

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)

我怎样才能在一个模型中实现这种关系?

python django relationship
2个回答
3
投票

你可以使用一个简单的ForeignKey来自我指示父项:

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

现在你可以做a2.parent = a1,并将自动访问a1.children.all()


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'.

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

您可以调整此示例来存储子项,而不是父项或者

© www.soinside.com 2019 - 2024. All rights reserved.