Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Django: Model Validation Error ManytoManyField

I get this error while running syncdb

Can't seem to figure out the issue. Please help.

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

Here are my models:

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)

Store Model:

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
like image 453
Eva611 Avatar asked Dec 05 '25 04:12

Eva611


1 Answers

Try doing something like this:

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

Also, if that doesn't work, try changing the related_name on the Business.logo field to something not logo_id. logo_id is what the database uses for the field and it may be having a conflict.

like image 187
Bryce Siedschlaw Avatar answered Dec 07 '25 19:12

Bryce Siedschlaw



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!