前言
开发环境中由于不断的添加和修改,多次执行了数据库迁移操作,在生产环境部署的时候我们需要进行重置。
重置方法
不保留数据库
删除数据库
删除数据迁移文件
python manage.py showmigrations [appname] #查看迁移文件
cd apps #切换到应用目录
find (*|app_name)/migrations/* -not -name __init__.py -delete #删除__init__.py以外的所有迁移文件
python manage.py showmigrations [appname] #查看迁移文件是否删除
重新迁移数据库
python manage.py makemigrations [appname] # 生成迁移文件
python manage.py showmigrations [appname] #查看迁移文件是否生成, 此时迁移文件显示[]xxx.py
python manage.py migrate [appname] # 执行迁移,可以看到django_migrations表产生迁移记录,数据库生成了需要的表
python manage.py showmigrations [appname] #查看迁移文件, 此时迁移文件显示[X]xxx.py
保留基础数据
删除迁移记录
# 重置迁移,--fake不会对数据库迁移对象进行实际操作,zero相当于从djang_migrations表中删除应用的迁移记录
python manage.py migrate --fake [appname] zero
# 查看想要重置的app的迁移文件,showmigrations时候显示为[]xxx.py而不是[X]xxx.py
python manage.py showmigrations [appname]
# 删除所有迁移文件
find (*|app_name)/migrations/* -not -name __init__.py -delete
# 查看是否删除
python manage.py showmigrations appname
重新执行迁移操作
# 生成迁移文件
python manage.py makemigrations [appname]
# 查看迁移文件是否生成, 此时迁移文件显示[]xxx.py
python manage.py showmigrations [appname]
# 执行迁移,可以看到django_migrations表产生迁移记录,没有实际操作迁移的数据库表
# 但是--fake-initial会检查表是否真实存在,操作需要确保数据库与迁移文件完全一致
python manage.py migrate --fake-initial [appname]
# 查看迁移文件, 此时迁移文件显示[X]xxx.py
python manage.py showmigrations [appname]
————————————————
版权声明:本文为CSDN博主「Let’s Golang」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_39974140/article/details/107998533