Django迁移失败

时间:2020-02-13 23:02:02

标签: django git virtualenv django-migrations

我有两个用于Django项目的开发机器-塔式和便携式计算机。我使用私有git repo来保持项目同步。我在塔上工作了一段时间,将更改提交到git repo(包括数据库),然后执行git pull origin master和git reset --hard origin / master,然后在旅行时在笔记本电脑上工作。

我似乎在某个地方犯了一个错误,因为当我如上所述更新笔记本电脑时,我的迁移过程中出现了错误。在塔上,所有迁移都是最新的并且已应用。在笔记本电脑上,我有一些无法应用的迁移。

 [X] 0044_remove_document_rotation
 [ ] 0041_remove_collectiondocument_position
 [ ] 0045_merge_20191023_1922
 [X] 0045_auto_20191121_1536
 [ ] 0046_merge_20200213_1523
 [X] 0046_auto_20200213_1541
 [ ] 0047_merge_20200213_1546

这些迁移都在塔上进行了检查。尝试在笔记本电脑上迁移时出现错误:

  Applying memorabilia.0041_remove_collectiondocument_position...Traceback (most recent call last):
  File "./manage.py", line 15, in <module>
    execute_from_command_line(sys.argv)
  File "/home/mark/.virtualenvs/memorabilia-JSON/lib/python3.6/site-packages/django/core/management/__init__.py", line 401, in execute_from_command_line
    utility.execute()
  File "/home/mark/.virtualenvs/memorabilia-JSON/lib/python3.6/site-packages/django/core/management/__init__.py", line 395, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "/home/mark/.virtualenvs/memorabilia-JSON/lib/python3.6/site-packages/django/core/management/base.py", line 328, in run_from_argv
    self.execute(*args, **cmd_options)
  File "/home/mark/.virtualenvs/memorabilia-JSON/lib/python3.6/site-packages/django/core/management/base.py", line 369, in execute
    output = self.handle(*args, **options)
  File "/home/mark/.virtualenvs/memorabilia-JSON/lib/python3.6/site-packages/django/core/management/base.py", line 83, in wrapped
    res = handle_func(*args, **kwargs)
  File "/home/mark/.virtualenvs/memorabilia-JSON/lib/python3.6/site-packages/django/core/management/commands/migrate.py", line 233, in handle
    fake_initial=fake_initial,
  File "/home/mark/.virtualenvs/memorabilia-JSON/lib/python3.6/site-packages/django/db/migrations/executor.py", line 117, in migrate
    state = self._migrate_all_forwards(state, plan, full_plan, fake=fake, fake_initial=fake_initial)
  File "/home/mark/.virtualenvs/memorabilia-JSON/lib/python3.6/site-packages/django/db/migrations/executor.py", line 147, in _migrate_all_forwards
    state = self.apply_migration(state, migration, fake=fake, fake_initial=fake_initial)
  File "/home/mark/.virtualenvs/memorabilia-JSON/lib/python3.6/site-packages/django/db/migrations/executor.py", line 245, in apply_migration
    state = migration.apply(state, schema_editor)
  File "/home/mark/.virtualenvs/memorabilia-JSON/lib/python3.6/site-packages/django/db/migrations/migration.py", line 114, in apply
    operation.state_forwards(self.app_label, project_state)
  File "/home/mark/.virtualenvs/memorabilia-JSON/lib/python3.6/site-packages/django/db/migrations/operations/fields.py", line 172, in state_forwards
    delay = not old_field.is_relation
AttributeError: 'NoneType' object has no attribute 'is_relation'

该项目同时在塔式计算机和便携式计算机上运行。

如何将这些迁移应用到笔记本电脑上,或删除引起问题的迁移?

谢谢!

标记

2 个答案:

答案 0 :(得分:0)

您是否尝试过在笔记本电脑上进行迁移? 这会将迁移标记为已应用,因此您不会再遇到麻烦。

创建一个迁移文件: python manage.py migrate --fake <APP_NAME> <MIGRATION>

为应用程序进行所有迁移: python manage.py migrate --fake <APP_NAME>

进行所有迁移: python manage.py migrate --fake

希望这会有所帮助!

致谢

答案 1 :(得分:0)

当我遇到这样的同步问题时,作为最后的选择,我经常删除迁移并从头开始。为此:

  1. 在迁移文件夹(例如0001.iniital.py和0002_auto_20191220_1357.py以及myproject / myproject / myapp / migrations /中的其他类似文件)中创建所有迁移的备份,然后删除它们。
  2. 转到Django数据库并删除django.migrations中的所有条目。
  3. 备份表,然后从MySQL(或其他)数据库中删除它们。

以上内容将为您提供一个完全干净的状态。

此后:

python manage.py makemigrations

其次:

python manage.py migrate

如果正确设置了模型,这将重新创建所有结构而不会出错。最后,检查备份的表,如果没有差异,则替换现有表。如果存在差异,请确保在同步之前进行必要的数据结构修改。

我发现,在处理可管理的数据库大小时,执行此方法通常比找出迁移出问题的链条要快。