Flask-Migrate的作用以及安装
程序员文章站
2022-05-05 16:29:19
1.因为采用db.create_all() 在后期修改表字段时,不会自动映射到数据库中,必须删除表,然后重新运行才会映射,这样不符合实际的需求,因此flask-Migrate就是为了解决这个问题,它可以在每次修改模型后,可以将修改的东西映射到数据库中。 2.首先进入到flask的虚拟环境或者物理环境 ......
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
更新数据库
(venv) $ python hello.py db upgrade
第一次迁移实际上相当于调用db.create_all(),但在后续迁移中,upgrade命令对表实施更新操作但不影响表中的内容。
上一篇: Java学习笔记二十五:Java面向对象的三大特性之多态
下一篇: 搞笑的鬼故事
推荐阅读
-
我的Node.js学习之路(三)--node.js作用、回调、同步和异步代码 以及事件循环_node.js
-
ubuntu 16.04 安装 python2.7 以及 cv2, dist-package 和 site-package 的区别, import cv2 出问题解答
-
SQL的作用、语句分类以及通用语法讲解
-
Python和Lua的默认作用域以及闭包
-
【转载】C#中SqlCommand类的作用以及常用方法
-
记录Mac上安装homebrew以及python3的过程
-
关于MySQL5.7.18的下载以及安装过程的图文详解
-
关于Ubuntu 16.04系统安装以及Nvidia显卡驱动安装的一些问题
-
安装win10+Ubuntu双系统后遇到的一些问题以及解决办法
-
python安装以及IDE的配置教程