例如,我有以下代码:
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)
我如何在一个模型中实现这种关系?
答案 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_data
和user_a2_data
必须是用户first_name
,last_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'.
注意:这是未经测试的示例代码,只是为了帮助您了解如何组织模型关系。这里的意图不是复制/粘贴就绪解决方案。
您可以调整此示例来代替或替代父项或
来存储子项