Django:“表不存在”错误
删除与应用程序关联的表并尝试使用syncdb重新同步数据库时命令时,可能会出现错误,表明该表不再存在。
原因:
丢失的表很可能是在删除相关应用程序的表时删除的表。 Django 在同步数据之前需要表存在。
解决方案:
要恢复丢失的表,请按照以下步骤操作:
创建迁移(Django 1.7 ):
如果 Django 版本为 1.7 或更高版本,则执行 makemigrations 命令:
python manage.py makemigrations
应用迁移(假运行):
应用使用 --fake 标志进行迁移,而无需实际更改数据库:
python manage.py migrate --fake
重新应用迁移(无假):
再次执行迁移,这次省略 --fake 标志以永久创建表:
python manage.py migrate
Django 的替代品 1.7:
对于 1.7 之前的 Django 版本,应该使用以下命令:python manage.py schemamigration someapp --auto python manage.py migrate someapp --fake通过以下步骤,可以成功恢复丢失的表并同步数据库正确。
以上是重新同步 Django 数据库时如何修复'表不存在”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!