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

 更新时间:2022年07月27日 14:52:46   作者:自由小冰儿  
Flask-Migrate是一个为Flask应用处理SQLAlchemy数据库迁移的扩展,使得可以通过Flask的命令行接口或者Flask-Scripts对数据库进行操作

前言

本篇文章,阐述一下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文件

到此这篇关于Python使用Flask Migrate模块迁移数据库的文章就介绍到这了,更多相关Python Flask Migrate内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python中accumulate函数的用法详解

    Python中accumulate函数的用法详解

    累积(accumulate)函数是Python标准库itertools中的一个强大工具,用于对可迭代对象进行累积操作,下面我们将深入探讨accumulate函数的用法,感兴趣的小伙伴可以了解下
    2023-11-11
  • 使用Matplotlib将图片保存为.tiff格式

    使用Matplotlib将图片保存为.tiff格式

    这篇文章主要介绍了使用Matplotlib将图片保存为.tiff格式问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • python安装cx_Oracle模块常见问题与解决方法

    python安装cx_Oracle模块常见问题与解决方法

    这篇文章主要介绍了python安装cx_Oracle模块常见问题与解决方法,举例分析了Python在Windows平台与Linux平台安装cx_Oracle模块常见问题、解决方法及相关注意事项,需要的朋友可以参考下
    2017-02-02
  • 深入探究PyTorch核心特性之自动求导和优化

    深入探究PyTorch核心特性之自动求导和优化

    在你已经掌握了如何使用PyTorch构建神经网络的基础上,接下来我们将深入探讨PyTorch的两个核心特性:自动求导(Autograd)和优化(Optimization),这两个特性在深度学习模型的训练过程中起着至关重要的作用,感兴趣的同学一起来看看吧
    2023-07-07
  • pycharm下载包的时候出现 no information available的解决

    pycharm下载包的时候出现 no information available的解决

    这篇文章主要介绍了pycharm下载包的时候出现 no information available的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • Python偏函数Partial function使用方法实例详解

    Python偏函数Partial function使用方法实例详解

    这篇文章主要介绍了Python偏函数Partial function使用方法实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • Python的Flask框架中SQLAlchemy使用时的乱码问题解决

    Python的Flask框架中SQLAlchemy使用时的乱码问题解决

    这篇文章主要介绍了Python的Flask框架中SQLAlchemy使用时的乱码问题解决,SQLAlchemy与Python结合对数据库的操作非常方便,需要的朋友可以参考下
    2015-11-11
  • pytorch 实现删除tensor中的指定行列

    pytorch 实现删除tensor中的指定行列

    今天小编就为大家分享一篇pytorch 实现删除tensor中的指定行列,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-01-01
  • 关于Python面向对象编程的知识点总结

    关于Python面向对象编程的知识点总结

    Python从设计之初就已经是一门面向对象的语言,正因为如此,在Python中创建一个类和对象是很容易的。下面这篇文章将详细给大家介绍关于Python面向对象编程的知识点,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-02-02
  • Python中getattr函数详解

    Python中getattr函数详解

    getattr是Python中的内置函数,用于获取一个对象的属性值,下面这篇文章主要给大家介绍了关于Python中getattr函数的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-11-11

最新评论