9

我正在尝试运行删除表中所有行的数据迁移(例如,MyModel)。还有另一个表指向该表 ( RelatedModel)。RelatedModel映射到的字段MyModelon_delete=models.SET_NULL。但是,当我运行迁移时,我得到:

  File "/usr/local/lib/python2.7/site-packages/django/db/backends/base/base.py", line 211, in _commit
    return self.connection.commit()
IntegrityError: update or delete on table "MyModel" violates foreign key constraint "f2274d6f2be82bbff458f3e5487b1864" on table "RelatedModel"
DETAIL:  Key (uuid)=(ywKMUYx7G2RoK9vqqEWZPV) is still referenced from table "RelatedModel".

我在迁移中添加了一个断点并检查了 SQL DELETE 查询。我在 shell 中以交互方式运行它们,它们在事务中工作,但是当它尝试提交迁移时,迁移仍然中断。但是我看不到哪个查询确切地导致了这个错误,所以我不知道如何调试它。有什么建议么?谢谢。

PS:我正在使用 Django 1.9.13、Python 2.7、PostgreSQL 10.4。

4

2 回答 2

5

您可以使用以下管理命令打印特定迁移的 SQL 语句。

python manage.py sqlmigrate <app label> <migration_name to print sql for>

例如,如果您想hello在 django 项目中检查应用程序的迁移,并假设您想为0001_initial.py. 比您需要执行以下行。

python manage.py sqlmigrate hello 0001_initial.py

它将打印将在迁移时执行的 SQL 定义(语句)。

于 2019-03-25T09:00:24.573 回答
1

使用 django-debug-toolbar 查看详细信息。或尝试: 1.根据需要使模型清晰。2.尝试删除除init文件之外的迁移。3.删除数据库文件。4. 现在迁移到应用程序 5. 然后迁移

于 2019-01-17T14:18:00.287 回答