天天看点

flask-migrate扩展

1.因为采用db.create_all() 在后期修改表字段时,不会自动映射到数据库中,必须删除表,然后重新运行才会映射,这样不符合实际的需求,因此flask-Migrate就是为了解决这个问题,它可以在每次修改模型后,可以将修改的东西映射到数据库中。

2.首先进入到flask的虚拟环境或者物理环境中 然后使用pip install flask-migrate进行安装;安装flask-script 支持命令行操作pip install flask-script

创建manage.py文件

from flask_script import Manager

from flask_migrate import Migrate,MigrateCommand

#主文件中导入app初始化manage

from zhihu import app

#db = SQLAlchemy()

from exts import db

#导入需要迁移的数据库模型

from models import User,Questions,Answer

#让python支持命令行工作

manager = Manager(app)

#使用migrate绑定app和db

migrate = Migrate(app,db)

#添加迁移脚本的命令到manager中

manager.add_command(‘db’,MigrateCommand)

if__name__==‘main’:

manager.run()
           

初始化

(venv) $ python manage.py db init

创建迁移脚本

(venv) $ python manage.py db migrate [-m xxxxx]

更新数据库

(venv) $ python hello.py db upgrade

查看历史记录

(venv) $ python hello.py db history

版本回退

(venv) $ python hello.py db downgrade 版本号

第一次迁移实际上相当于调用db.create_all(),但在后续迁移中,upgrade命令对表实施更新操作但不影响表中的内容。