zoukankan      html  css  js  c++  java
  • 数据库迁移时遇到的问题以及迁移的执行过程

    问题1

    执行 migrate命令时报错:

    上面报错的意思是:缺少依赖的应用 customer 

    解决的方法是:执行migrations命令的时候加上customer这个应用就好了:

    python3 manage.py makemigrations customer

    接下来再执行 migrate 命令就没问题了:

    问题2

    然后再一次执行migrate的时候又上报了错误:

    解决的方法是先执行一次下面这段命令(在migrate后面加上 --fake 参数):

    python manage.py migrate --fake

    然后再执行 migrate 就没问题了~

    数据库迁移的执行过程说明

    1、在执行 python manage.py makemigrations  的时候django会在相应的app的makemigrations 目录下生成一个py脚本文件

    2、在执行 python manage.py migrate 的时候django才会在数据库中生成对应的表,那django是如何知道应该执行哪个文件呢?

    首先,每个migrations目录可能有多个脚本,django是通过一张django-migrations表来进行判断的,这章django-migrations表记录了已经执行过的脚本——也就是说,没有执行的脚本就没有在这张表中记录,于是在执行migrate的时候只会执行表中没有记录的脚本。

    3、如果有的时候执行 migrate 的时候发现没有生成对应的表,可以看看在django-session表中有没有脚本的记录——也就是这个脚本有没有执行。

    4、有时我们可以删除django-session表中的记录数据库相应的表,重新执行命令生成对应的表。

  • 相关阅读:
    Windows打开文件后提示,文件或目录损坏无法读取。
    windows10 提示内存不足
    配置Redis集群为开机自启动
    Hbase的rowkey设计
    Hbase表类型的设计
    mycat的下载和安装
    mycat简介
    mysql|tomcat|nginx|redis在docker中的部署
    docker的备份和迁移
    Redis Cluster集群详介绍和伪集群搭建
  • 原文地址:https://www.cnblogs.com/lulin9501/p/11178327.html
Copyright © 2011-2022 走看看