零、前言 本篇文章,阐述一下Flask中数据库的迁移
文章图片
为什么要说数据库迁移呢?安装 【flask|(零八)Flask有手就行——数据库迁移Flask-Migrate】直接使用
比如我们以前有一个数据库,里面的信息有id, name
现在我想再加一个gender
属性,应该怎么办呢?不可能直接把数据库删除掉吧。然后重新创建一个,因此本文介绍一种,通过数据库迁移的方法,可以保留原始的数据,并完成添加新的一列的方法。
pip install flask-migrate
即可初始化 项目结构
# exts.py
from flask_sqlalchemy import SQLAlchemy
db = SQLAlchemy()
老样子,我们还是在exts.py中,初始我们的数据库,这里时放Flask扩展的地方。
# models.py
from exts import dbclass 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 Migrateapp = 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 409392ed6301409392ed6301
是问题的版本号- 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
文件
文章图片
推荐阅读
- vuejs|基于Flask + Vue前后端分离的资产管理系统实现
- python|Python序列以及切片操作
- flask框架快速入门|【flask高级】从源码深入理解flask的应用上下文和请求上下文
- CTF|Flask SSTI注入学习
- FDTD学习笔记|Lumerical官方案例、FDTD时域有限差分法仿真学习(十五)——y分支的逆向设计(Inverse design of y-branch)
- 其他|Redis学习
- 工作|GPS、GIS与导航全概述
- python|LeetCode 括号生成
- 笔记|解决ModularNotFoundError: No module named “cv2.aruco“