gpt4 book ai didi

Django - 反向查询名称冲突

转载 作者:行者123 更新时间:2023-12-04 05:40:24 26 4
gpt4 key购买 nike

我在 Django 中放置了一个循环外键,这导致了名称冲突。我不明白为什么会发生冲突或如何最好地补救。 (这是我第一次在模型中使用循环引用 - 所以我不确定这是否可能是问题的根本原因?)

对于以下:

class Supplier(models.Model):
unique_id = models.IntegerField(unique=True)
name = models.CharField(max_length=255, unique=True)
rating = models.FloatField(null=True)
last_updated = models.DateTimeField(auto_now=True)
default_tariff = models.ForeignKey('Tariff')

class Tariff(models.Model):
name = models.CharField(max_length=255)
supplier = models.ForeignKey(Supplier)
end_date = models.DateField(null=True, blank=True)
payment_method = models.ManyToManyField(PaymentMethod)
region = models.ManyToManyField(Region)

错误是:

Reverse query name for 'Supplier.default_tariff' clashes with field name 'Tariff.supplier'. HINT: Rename field 'Tariff.supplier', or add/change a related_name argument to the definition for field 'Supplier.default_tariff'.

最佳答案

为避免这种情况,您可以使用 related_name :

class Supplier(models.Model):
unique_id = models.IntegerField(unique=True)
name = models.CharField(max_length=255, unique=True)
rating = models.FloatField(null=True)
last_updated = models.DateTimeField(auto_now=True)
default_tariff = models.ForeignKey('Tariff', related_name='+')

class Tariff(models.Model):
name = models.CharField(max_length=255)
supplier = models.ForeignKey(Supplier)
end_date = models.DateField(null=True, blank=True)
payment_method = models.ManyToManyField(PaymentMethod)
region = models.ManyToManyField(Region)
从评论中编辑:
当您设置 related_name="+"时,Django 不会创建向后关系。在这种情况下,关税将与供应商模型没有反向关系。

关于Django - 反向查询名称冲突,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34003865/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com