美文网首页
Django迁移错误migrate

Django迁移错误migrate

作者: 创造new_world | 来源:发表于2020-03-30 00:23 被阅读0次

    参考:https://www.jianshu.com/p/ebe84b8fa365?utm_campaign=hugo&utm_medium=reader_share&utm_content=note&utm_source=weixin-friends

    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

    相关文章

      网友评论

          本文标题:Django迁移错误migrate

          本文链接:https://www.haomeiwen.com/subject/rfzpuhtx.html