[英]Django + postgres relation does not exist error
我知道这件事有多少问题,但建议的解决方案都没有帮助。 我遇到了以下问题:我删除了我的模型并删除了admin.py
中的导入。 然后我想用makemigrations
更新 django 数据库,这表明它删除了模型员工,但是在使用migrate
命令后,我看到了一个关系不存在的错误。 我还从我使用的 postgres 数据库中删除了它。 这里奇怪的是, migrate 一直在寻找不存在的模型。 即使我创建另一个makemigrations
检测到它然后migrate
说relation project_employee..
尝试过syncdb --all
没有成功。 这是migrate
的输出
Apply all migrations: sessions, project, admin, auth, contenttypes
Running migrations:
Applying project.0003_auto_20160318_1215...Traceback (most recent call last):
File "/usr/lib/python3/dist-packages/django/db/backends/utils.py", line 65, in execute
return self.cursor.execute(sql, params)
psycopg2.ProgrammingError: relation "project_employee" does not exist
The above exception was the direct cause of the following exception:
Traceback (most recent call last):
File "manage.py", line 10, in <module>
execute_from_command_line(sys.argv)
File "/usr/lib/python3/dist-packages/django/core/management/__init__.py", line 385, in execute_from_command_line
utility.execute()
File "/usr/lib/python3/dist-packages/django/core/management/__init__.py", line 377, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
File "/usr/lib/python3/dist-packages/django/core/management/base.py", line 288, in run_from_argv
self.execute(*args, **options.__dict__)
File "/usr/lib/python3/dist-packages/django/core/management/base.py", line 338, in execute
output = self.handle(*args, **options)
File "/usr/lib/python3/dist-packages/django/core/management/commands/migrate.py", line 161, in handle
executor.migrate(targets, plan, fake=options.get("fake", False))
File "/usr/lib/python3/dist-packages/django/db/migrations/executor.py", line 68, in migrate
self.apply_migration(migration, fake=fake)
File "/usr/lib/python3/dist-packages/django/db/migrations/executor.py", line 102, in apply_migration
migration.apply(project_state, schema_editor)
File "/usr/lib/python3/dist-packages/django/db/migrations/migration.py", line 108, in apply
operation.database_forwards(self.app_label, schema_editor, project_state, new_state)
File "/usr/lib/python3/dist-packages/django/db/migrations/operations/fields.py", line 84, in database_forwards
schema_editor.remove_field(from_model, from_model._meta.get_field_by_name(self.name)[0])
File "/usr/lib/python3/dist-packages/django/db/backends/schema.py", line 431, in remove_field
self.execute(sql)
File "/usr/lib/python3/dist-packages/django/db/backends/schema.py", line 111, in execute
cursor.execute(sql, params)
File "/usr/lib/python3/dist-packages/django/db/backends/utils.py", line 81, in execute
return super(CursorDebugWrapper, self).execute(sql, params)
File "/usr/lib/python3/dist-packages/django/db/backends/utils.py", line 65, in execute
return self.cursor.execute(sql, params)
File "/usr/lib/python3/dist-packages/django/db/utils.py", line 94, in __exit__
six.reraise(dj_exc_type, dj_exc_value, traceback)
File "/usr/lib/python3/dist-packages/django/utils/six.py", line 658, in reraise
raise value.with_traceback(tb)
File "/usr/lib/python3/dist-packages/django/db/backends/utils.py", line 65, in execute
return self.cursor.execute(sql, params)
django.db.utils.ProgrammingError: relation "project_employee" does not exist
`
谢谢
AFAIK,您不应该在迁移之前直接从数据库中删除表。 如果您更改模型,那么manage.py migrate
将执行此操作。
django 无法检测到 DB 的直接变化; 只知道模型脚本的变化。 因此,如果你删除了一个表,那么 django 不会检测到更改,因此 django 会继续寻找被删除的表并给出错误。
有时迁移无缘无故不起作用。 在这种情况下,我会做以下事情:
manage.py makemigrations appname
比manage.py makemigrations
效果更好)这有时有效。
使用以下代码删除数据库中的表
python manage.py migrate app_name zero
然后再次迁移
python manage.py migrate app_name
原因是已经存在一个表,当您进行“初始迁移”时,Django 将看到初始迁移已经应用,因为该表已经存在于旧模式中,因此不会采用不同的新表模式考虑在内。
我能够通过以下步骤解决此问题
当我运行这个命令时
python manage.py migrate app_name zero
它抱怨缺少一些桌子。 所以我创建了一个带有虚拟列的虚拟表。
我再次运行命令
python manage.py migrate app_name zero
我已经为该应用应用了迁移
python manage.py migrate app_name
最终帮助的是从项目文件夹中删除整个迁移文件夹。 也看到了一些南方的回应,但还没有尝试过。
我需要做的就是创建一个具有相同名称和一个虚拟列的表。 然后,当我迁移时,django 为我重新制作了所有列。
我为我做的是使用下面的命令伪造迁移
python3 manage.py migrate yourapp --fake
我的一个 necro,但是如果您在具有现有数据和活动迁移(Django,Postgres)的项目上删除了一个表,您最好的选择是删除整个数据库(当然要谨慎行事),重新创建它,然后运行管理.py migrate 重新初始化您的环境。
这是软重置并与当前版本同步的最快方法。
最后,它对我有用。 我必须删除所有表,然后删除迁移文件。
然后手动尝试以下命令:
python manage.py makemigrations [appname]
python manage.py migrate [appname]
最后这对我有用:
python manage.py makemigrations [app_name]
python manage.py migrate [app_name]
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.