Python使用Flask Migrate模块迁移数据库

作者:自由小冰儿 时间:2023-08-10 09:17:30 

前言

本篇文章,阐述一下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&lsquo;t locate revision identified by '409392ed6301'

答:db revision --rev-id 409392ed6301 409392ed6301是问题的版本号

Error: While importing &lsquo;app&rsquo;, an ImportError was raised.

答:请先去运行一下app.py,确保app.py可以运行

Error: Could not locate a Flask application. You did not provide the &ldquo;FLASK_APP&rdquo; environment variable, and a &ldquo;wsgi.py&rdquo; or &ldquo;app.py&rdquo; module was not found in the current directory. 答:请确保执行命令时的文件夹中有app.py文件

来源:https://blog.csdn.net/qq_43497702/article/details/125878272

标签:Python,Flask,Migrate,迁移,数据库
0
投稿

猜你喜欢

  • python tkinter制作用户登录界面的简单实现

    2021-01-07 06:00:09
  • Python读大数据txt

    2021-12-29 20:34:12
  • python实现简单颜色识别程序

    2022-07-15 09:34:47
  • PHP基于phpqrcode类生成二维码的方法示例详解

    2023-07-15 22:57:52
  • django和vue互传图片并进行处理和展示

    2021-04-24 20:39:16
  • 详解Python下Flask-ApScheduler快速指南

    2023-12-25 07:37:34
  • Python登录系统界面实现详解

    2021-02-11 19:24:04
  • MySQL 5.7.18 免安装版配置教程

    2024-01-16 06:12:51
  • asp伪继承初探_实例代码

    2011-04-19 10:32:00
  • python2 与 python3 实现共存的方法

    2023-06-13 23:56:29
  • Python超详细分步解析随机漫步

    2022-03-04 07:14:08
  • 推荐19个很有用的 JavaScript 库

    2011-05-14 16:33:00
  • SQLServer导出数据到MySQL实例介绍

    2024-01-13 08:07:17
  • 解决import tensorflow as tf 出错的原因

    2023-06-26 23:53:21
  • c#数据库与TXT导入导出的实例

    2024-01-24 06:34:16
  • PHP const定义常量及global定义全局常量实例解析

    2023-11-17 07:24:57
  • 详解Python3.8+PyQt5+pyqt5-tools+Pycharm配置详细教程

    2021-08-11 14:08:22
  • mysql报错:MySQL server version for the right syntax to use near type=InnoDB的解决方法

    2024-01-20 19:17:17
  • Python netmiko模块的使用

    2021-07-04 06:42:51
  • Golang 函数执行时间统计装饰器的一个实现详解

    2024-05-09 09:46:22
  • asp之家 网络编程 m.aspxhome.com