Django迁移错误migrate

Django迁移之migrate问题:table xx already exist

前面我们说到了makemigrations是将models.py里的模型生成一个迁移脚本【也就是migration文件】,下一步则是通过migrate命令来在数据库中生成表,这个步骤中往往也会遇到大大小小的问题。

一、migrate命令原理

1.1 执行的操作

要解决问题,需要知道命令到底执行了些什么操作:

  1. migrate 将相关的迁移脚本翻译成SQL语句,然后在数据库中执行该语句
  2. 若该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
    

你可能感兴趣的:(Django迁移错误migrate)