Django,ManyToManyField - ProgrammingError:关系foo_bar不存在。在迁移中得到认可,但从未创建过关系

时间:2015-01-06 05:13:50

标签: python sql django postgresql django-models

在这种情况下,“foo_bar”实际上是“links_userprofile_favorite_feeds”。

问题是,当我进入manage.py shell时:

manage.py shell

from django.contrib.auth.models import User
from feeds.models import feed
p = User.objects.get(username='myuser')
p.save()
q = Feed.objects.get(title='myfeed')
q.save()
p.userprofile.favorite_feed.add(q)

我得到了

错误:

ProgrammingError: relation "links_userprofile_favorite_feeds" does not exist
LINE 1: ..."links_userprofile_favorite_feeds"."feed_id" FROM "links_use...

以下是相关文件和追溯:

links.models.py

class UserProfile(models.Model):
    user = models.OneToOneField(User,unique=True)
    bio = models.TextField(null=True)
    thumbnail = models.ImageField(upload_to="uploaded_files/")  
    favorite_feeds = models.ManyToManyField(Feed)

feeds.models.py

class Feed(models.Model):
    title = models.CharField(max_length=25)
    slug = models.SlugField(max_length=25)

    def save(self, *args, **kwargs):
        if not self.slug:
            #Newly created object, so set slug
            self.slug = slugify(self.title)

        super(Feed,self).save(*args,**kwargs)

    def __unicode__(self):
        return self.title

    class Meta:
        ordering = ('title',)

这种关系似乎存在于迁移中,但manage.py syncdb, manage.py makemigrations, manage.py migrate,都不起作用(不应用迁移)。

有人可以帮忙吗?我想创建关系"links_userprofile_favorite_feeds."

1 个答案:

答案 0 :(得分:2)

固定。

对于将来遇到此问题的人:

  1. 从数据库中删除所有links_ *表(应用程序称为“链接”)
  2. 通过执行以下操作删除“链接”应用的所有迁移:

    from django.db.migrations.recorder import MigrationRecorder
    MigrationRecorder.Migration.objects.filter(app='links').delete()
    
  3. 使用manage.py migrate

  4. 向前迁移