目录
前言安装初始化项目结构三大命令前言
本篇文章,阐述一下Flask中数据库的迁移
为什么要说数据库迁移呢?
(资料图片仅供参考)
比如我们以前有一个数据库,里面的信息有 id, name
现在我想再加一个gender
属性,应该怎么办呢?不可能直接把数据库删除掉吧。然后重新创建一个,因此本文介绍一种,通过数据库迁移的方法,可以保留原始的数据,并完成添加新的一列的方法。
安装
直接使用pip install flask-migrate
即可
初始化
项目结构
# exts.py from flask_sqlalchemy import SQLAlchemy db = SQLAlchemy()
老样子,我们还是在exts.py中,初始我们的数据库,这里时放Flask扩展的地方。
# models.py from exts import db class User(db.Model): id = db.Column(db.Integer,primary_key=True) username = db.Column(db.String(80),unique=True) def __repr__(self): return "" % self.username
models.py
是放模型的地方。
# app.py from flask import Flask from exts import db from flask_migrate import Migrate app = Flask(__name__) app.config["SQLALCHEMY_DATABASE_URI"] = "sqlite:///foo.db" # !!!绑定app和数据库 db.init_app(app) migrate = Migrate(app,db) if __name__ == "__main__": app.run()
主程序,我们在!!!
进行初始化数据库迁移的migrate
对象。初始化之后我们可以执行下面的三大命令去创建我们的数据库。就不需要db.create_all()
命令啦。
三大命令
# (1)初始化
flask db init
# 把当前的模型添加到迁移文件
flask db migrate
# 将映射文件真正的映射到数据库中
flask db upgrade
(1)新建一个名字为migrations的文件夹,并且记录一个数据库版本号
其他问题:
如果报错[flask_migrate] Error: Can‘t locate revision identified by "409392ed6301"
答:db revision --rev-id 409392ed6301 409392ed6301是问题的版本号
Error: While importing ‘app’, an ImportError was raised.
答:请先去运行一下app.py,确保app.py可以运行
Error: Could not locate a Flask application. You did not provide the “FLASK_APP” environment variable, and a “wsgi.py” or “app.py” module was not found in the current directory. 答:请确保执行命令时的文件夹中有app.py文件
到此这篇关于Python使用Flask Migrate模块迁移数据库的文章就介绍到这了,更多相关Python Flask Migrate内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
X 关闭
X 关闭
- 1转转集团发布2022年二季度手机行情报告:二手市场“飘香”
- 2充电宝100Wh等于多少毫安?铁路旅客禁止、限制携带和托运物品目录
- 3好消息!京东与腾讯续签三年战略合作协议 加强技术创新与供应链服务
- 4名创优品拟通过香港IPO全球发售4100万股 全球发售所得款项有什么用处?
- 5亚马逊云科技成立量子网络中心致力解决量子计算领域的挑战
- 6京东绿色建材线上平台上线 新增用户70%来自下沉市场
- 7网红淘品牌“七格格”chuu在北京又开一家店 潮人新宠chuu能红多久
- 8市场竞争加剧,有车企因经营不善出现破产、退网、退市
- 9北京市市场监管局为企业纾困减负保护经济韧性
- 10市场监管总局发布限制商品过度包装标准和第1号修改单