0

假设我有一个名为“parent”的 ForeignKey 字段,其 related_name 为“children”:

class Item(PolymorphicModel):
    title = models.CharField()
    parent = models.ForeignKey(
        "self", related_name='children', null=True, blank=True, on_delete=models.CASCADE)

class Parent(Item):
    pass

class Child(Item):
    pass

为什么我只能将孩子添加到父母,但如果我尝试将父母添加到孩子,我会收到错误消息?

所以这有效:

p1 = Parent.objects.create(title="Parent 1")
c1 = Child.objects.create(title="Child 1")

print(p1.children)
#<PolymorphicQuerySet []>

p1.children.add(c1)

但这不会:

p1 = Parent.objects.create(title="Parent 1")
c1 = Child.objects.create(title="Child 1")
print(c1.parent)
# None

c1.parent.add(p1)
# AttributeError: 'NoneType' object has no attribute 'add'

我每次都必须添加到父母的孩子字段吗?有没有办法添加到孩子的父母呢?是否有任何理由为什么添加到孩子的父母不起作用或不应该使用?

在这种情况下(如果相关),我对何时/如何使用“_set”也有些困惑。因此,按照Django 的多对一示例的格式,以下内容也不适用于我:

p1 = Parent.objects.create(title="Parent 1")
c1 = Child.objects.create(title="Child 1")
p1.children.add(c1)

print(p1.children_set.all())
# AttributeError: 'p1' object has no attribute 'children_set'

print(c1.parent_set.all())
# AttributeError: 'c1' object has no attribute 'parent_set'

print(p1.item_set.all())
# AttributeError: 'p1' object has no attribute 'item_set'
4

1 回答 1

0

所以我认为你在这里混淆了自己parent并在这里child命名。中的related_name字段ForeignKey本质上告诉模型建立关系以快速找到具有给定的模型的所有相关实例ForeignKey。当您调用时p1.children,您将获得正确的输出,因为没有相关的实例p1。当您调用c1.parent并获取时,您同样会得到正确的输出None。我在下面复制并粘贴的行是导致这种情况的原因。通过设置null=True,您是说使用 null字段(在 python 中, null 是)实例化Item实例(无论是Parent还是)。ChildparentNone

当您打电话时,您的感知问题就出现了c1.parent.add()。由于您没有设置parent任何内容,因此它的值为None,并且它同样没有add()方法。你应该做的是设置parent=[some instance of Parent]。然后,当您想要获取children给定Parent实例的 时,假设p1您可以调用p1.children,您将获得一个充满Child实例的查询集,其parent字段已设置为该Parent实例的外键。

parent = models.ForeignKey(
    "self", related_name='children', null=True, blank=True, on_delete=models.CASCADE)
于 2021-01-06T03:39:28.173 回答