如何查看导致Django迁移错误的SQL查询?

Ari*_*iel 6 django postgresql django-migrations

我正在尝试运行数据迁移,删除表中的所有行(比方说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".
Run Code Online (Sandbox Code Playgroud)

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

PS:我正在使用Django 1.9.13,Python 2.7,PostgreSQL 10.4.

Dev*_*yar 9

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

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

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

python manage.py sqlmigrate hello 0001_initial.py

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


Bla*_*Sql 0

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