日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Python使用Flask?Migrate模塊遷移數據庫_python

作者:自由小冰兒 ? 更新時間: 2022-09-20 編程語言

前言

本篇文章,闡述一下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 '<User %s>' % 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文件

原文鏈接:https://blog.csdn.net/qq_43497702/article/details/125878272

欄目分類
最近更新