我正在运行南迁移python manage.py syncdb; python manage.py migrate --all
,在新数据库上运行时会中断。但是,如果你运行它两次,它就会正常运行!在第一次尝试时,我得到
DoesNotExist: ContentType matching query does not exist. Lookup parameters were {'model': 'mymodel', 'app_label': 'myapp'}
失败后,我进入数据库select * from django_content_type
,但果然有
13 | my model | myapp | mymodel
然后我运行迁移python manage.py syncdb; python manage.py migrate --all
,它可以工作!
那么,我是如何设法进行仅第二次有效的迁移呢?顺便说一句,这是一个将适当的组放入管理应用程序的数据迁移。迁移中的以下方法正在破坏它:
@staticmethod
def create_admin_group(orm, model_name, group_name):
model_type = orm['contenttypes.ContentType'].objects.get(app_label='myapp', model=model_name.lower())
permissions = orm['auth.Permission'].objects.filter(content_type=model_type)
group = orm['auth.Group']()
group.name = group_name
group.save()
group.permissions = permissions
group.save()
(迁移文件来自一个现有的工作项目,这意味着很久以前我已经运行了 schemamigration --initial。我只是试图将数据库模式和初始数据复制到一个新的数据库中。)