django 数据库迁移命令详解

解决数据库迁移的终级(不删数据库)方案
# 01 清空django_migrations所有记录
delete FROM public.django_migrations
# 02  清空工程目录下的所有迁移文件
find . -path "*/migrations/*.py" -not -name "__init__.py" -delete
find . -path "*/migrations/*.pyc"  -delete
******如果,你确定数据库与app的models.py同步,则不需要第03与04步骤*****
# 03 导出数据库表结构为模型文件
python manage.py inspectdb > ./db_models.py
# 04 核查每个app的模型文件与db_models.py中有无差异?有差异需要依据数据库修改app下的models.py文件
- 这里需要备份每个app的models.py, 人工check与修改models.py保持与数据库同步。
# 05 创建本地迁移文件
python manage.py makemigrations
# 06 提交迁移文件至数据库
python manage.py migrate --fake
# 07 还原自己最新的app中的models.py文件
- 手工替换一下
# 08 按常规操作进行数据库迁移与同步
....................开始迁移与写代码吧...............
1. migrate参数说明
位置参数:
  app_label            指定同步的应用程序标签.
  migration_name        Database state will be brought to the state after that
                        migration. Use the name "zero" to unapply all
                        migrations.

可选参数:
  -h, --help            show this help message and exit
  --noinput, --no-input 告诉Django不要提示用户输入任何类型的信息。.
  --database DATABASE   指定要同步的数据库。默认为“default”数据库.
  --fake                将迁移标记为运行而不实际运行它们.
  --fake-initial        检测表是否已经存在,假若已经应用了初始迁移。在使用此标志之前,请确保当前数据库架构与初始迁移匹配。Django只检查一个现有的表名。
  --plan                显示将要执行的迁移操作的列表.
  --run-syncdb     为不进行迁移的应用程序创建表。
  --version             显示程序的版本号和退出
                    -v {0,1,2,3}, --verbosity {0,1,2,3}
                        Verbosity level; 0=minimal output, 1=normal output,
                        2=verbose output, 3=very verbose output
  --settings SETTINGS   设置模块的Python路径,例如“myproject.settings.main”如果未提供此选项,则将使用DJANGO_SETTINGS_MODULE环境变量。
  --pythonpath Python path要添加到Python路径的目录,例如“/home/djangoprojects/myproject”。
  --traceback           Raise on CommandError exceptions
  --no-color            不要将命令输出着色。
  --force-color        强制命令输出着色。
2. makemigrations参数说明
位置参数:
  app_label          指定要为其创建迁移的应用程序标签.
可选参数:
  --dry-run             只需显示将要进行的迁移;不要实际编写它们。
  --merge               启用迁移冲突的修复。
  --empty               创建空迁移.
  --noinput, --no-input 告诉Django不要提示用户输入任何类型的信息.
  -n NAME, --name 名称,将此名称用于迁移文件.
  --no-header           不要向新迁移文件添加头注释。
  --check               如果模型更改丢失迁移,则以非零状态退出.
  --version             show program's version number and exit
  -v {0,1,2,3}, --verbosity {0,1,2,3}
                        Verbosity level; 0=minimal output, 1=normal output,
                        2=verbose output, 3=very verbose output
  --settings SETTINGS   The Python path to a settings module, e.g.
                        "myproject.settings.main". If this isn't provided, the
                        DJANGO_SETTINGS_MODULE environment variable will be
                        used.
  --pythonpath PYTHONPATH
                        A directory to add to the Python path, e.g.
                        "/home/djangoprojects/myproject".
  --traceback           Raise on CommandError exceptions
  --no-color            Don't colorize the command output.
  --force-color         Force colorization of the command output.

你可能感兴趣的:(django 数据库迁移命令详解)