django migrations

Django不删库数据迁移方案

不删库数据迁移方案

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# 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 按常规操作进行数据库迁移与同步
....................开始迁移与写代码吧...............

migrate

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
位置参数:
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 强制命令输出着色。

makemigrations

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
位置参数:
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.
坚持原创技术分享,您的支持将鼓励我继续创作!
0%