3

运行 syncdb 时出现此错误

似乎无法弄清楚问题所在。请帮忙。

    Error: One or more models did not validate:
store.business: Reverse query name for field 'logo' clashes with field 'ImageBank.business'. Add a related_name argument to the definition for 'logo'.

这是我的模型:

class Business(models.Model):
    business_type = models.ManyToManyField(BusinessType)
    business_service_type = models.ManyToManyField(ServiceType)
    establishment_type = models.ForeignKey(EstablishmentType)
    logo = models.ForeignKey(ImageBank, related_name = '%(class)s_logocreated',)
    phone = PhoneNumberField()
    address = models.ForeignKey(Address)
    website = models.URLField()
    name = models.CharField(max_length=64)

    def __unicode__(self):
        return self.name

class ImageBank(models.Model):
    business = models.ForeignKey('Business', related_name='%(class)s_business')
    image = models.ImageField(upload_to="images/bank")

    def url(self):
        return self.image.url

    def __unicode__(self):
        return unicode(self.business) + " : " + unicode(self.image)

店铺型号:

class Store(models.Model):
    business = models.ForeignKey(Business,null=True, related_name='business_creator_set')
    condition = models.CharField(verbose_name='What do customers have to do?',max_length = 50)
    reward = models.CharField(verbose_name='What do customers win?',max_length = 50)
    display = models.BooleanField(default=True)
    date_created = models.DateTimeField(default=datetime.now)


    def __unicode__(self):
        return self.condition + ", " + self.reward
4

1 回答 1

1

尝试做这样的事情:

...
class ImageBank(models.Model):
    business = models.ForeignKey('Business', related_name='%(class)s_business')
....

此外,如果这不起作用,请尝试将 Business.logo 字段中的 related_name 更改为非 logo_id 的名称。logo_id 是数据库用于该字段的内容,它可能存在冲突。

于 2011-05-11T17:01:02.543 回答