在做项目的过程中,我们都遇到过,经常需要修改我们数据库的字段,在flask中,是通过ORM(对象关系映射)来创建数据库的,表--->model class,字段---->属性
在flask中,我们是通过第三方插件SQLAlchemy来创建数据库表,采用的是db.create_all()方法,这样,在我们修改数据库的Model的字段之后,想要同步数据库,就只能通过删除表,然后重新调用db.create_all()来完成。
所以,flask引入了flask_script 和 flask_migrate(pip install)来解决这个问题:
1、新建manager.py文件,编写如下:
from flask_script import Manager
from flask_migrate import Migrate, MigrateCommond
from app import app
from apps.models.base import db
manager = Manager(app)
# 要使用flask-migrate,必须先绑定db和app
migrate = Migrate(app, db)
# 将MigrateCommand添加到manager中,"db"是自定义命令
manager.add_command("db", MigrateCommond)