Django迁移之migrate问题:table xx already exist
前面我们说到了makemigrations是将models.py里的模型生成一个迁移脚本【也就是migration文件】,下一步则是通过migrate命令来在数据库中生成表,这个步骤中往往也会遇到大大小小的问题。
一、migrate命令原理
1.1 执行的操作
要解决问题,需要知道命令到底执行了些什么操作:
- migrate 将相关的迁移脚本翻译成SQL语句,然后在数据库中执行该语句
- 若该SQL语句执行没有问题,那么就会将这个迁移脚本的名字记录到django_migrations表中
1.2 判断执行条件
那么如何判断哪些迁移脚本要执行呢?
migrate会将代码中的迁移脚本和数据库中的django_migrations 中的迁移脚本进行对比,如果发现数据库中,没有这个迁移脚本,那么就会执行这个迁移脚本。
二、migrate命令报错原理
原因:数据库的django_migrations 表中的迁移版本记录和代码中的迁移脚本不一致导致的。
常见错误示例:
table xx already exist
三、 解决方法
1、方法1: --fake参数
这一个参数是用于,将已经创立的表的迁移操作隐藏,即将代码中的迁移脚本添加到django_migrations中,但并不执行SQL语句,避免每次执行migrate的时候,都执行一些重复的迁移脚本。
python manage.py migrate app_name --fake
再正常执行迁移映射操作即可
2、方法2: 简单粗暴法
这一步如其名一样简单,删除了所有相关迁移脚本和迁移记录后,重新完全迁移。!!!需要保持数据库和模型字段一致!!!
删除migration文件夹下,除____pycache____和____init____之外的所有文件【即迁移脚本】。
-
删除数据库中,相关字段的所有信息
delete from django_migrations where app = app_name
-
重新执行迁移操作
python manage.py makemigrations python manage.py migrate