如何使用Flask-Migrate拓展数据库表结构


Posted in Python onJuly 24, 2019

前言

在我们用 sqlchemy 模块创建完几个表时,如果在实际生产环境中,需要对表结构进行更改,应该怎么办呢?总不能把表删除了吧,这样数据就会丢失了。

更好的解决办法是使用数据库迁移框架,它可以追踪数据库模式的变化,然后把变动应用到数据库中。

在Flask中可以使用Flask-Migrate扩展,来实现数据迁移。并且集成到Flask-Script中,所有操作通过命令就能完成。

操作示例:

1.首先需要安装 flask-migrate 模块,当然还有 flask-script 模块。

pip3 install flask-migrate
pip3 install flask-script

2.代码:

#coding=utf-8
from flask import Flask

from flask_sqlalchemy import SQLAlchemy
from flask_migrate import Migrate,MigrateCommand
from flask_script import Shell,Manager

app = Flask(__name__)
manager = Manager(app)

app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root:mysql@127.0.0.1:3306/Flask_test'
app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN'] = True
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = True
db = SQLAlchemy(app)

#第一个参数是Flask的实例,第二个参数是Sqlalchemy数据库实例
migrate = Migrate(app,db) 

#manager是Flask-Script的实例,这条语句在flask-Script中添加一个db命令
manager.add_command('db',MigrateCommand)

#定义模型Role
class Role(db.Model):
  # 定义表名
  __tablename__ = 'roles'
  # 定义列对象
  id = db.Column(db.Integer, primary_key=True)
  name = db.Column(db.String(64), unique=True)
  user = db.relationship('User', backref='role')

  #repr()方法显示一个可读字符串,
  def __repr__(self):
    return 'Role:'.format(self.name)

#定义用户
class User(db.Model):
  __talbe__ = 'users'
  id = db.Column(db.Integer, primary_key=True)
  username = db.Column(db.String(64), unique=True, index=True)
  #设置外键
  role_id = db.Column(db.Integer, db.ForeignKey('roles.id'))

  def __repr__(self):
    return 'User:'.format(self.username)


if __name__ == '__main__':
  manager.run()

主要注意第8行-20行,48行。要把原来的代码改成这样。

3.命令行的操作

创建迁移仓库

这个命令会创建 migirations 文件夹,所有迁移文件都放在里面

python3 xxx.py db init

注:db 是20行决定了,可以更改

自动创建迁移脚本

python3 xxx.py db migrate -m"版本名(注释)"

更新数据库

python3 xxx.py db upgrade

当我们需要修改表结构时,直接在 xxx.py 里直接增删相应的代码

修改完成后,继续创建新的迁移脚本

python 文件 db migrate -m"新版本名(注释)"

更新数据库

python3 xxx.py db upgrade

更新完之后,其实就是提交操作,类似于 git 添加一个新的版本。

但是,如果我们想返回历史的版本,应该怎么操作呢?

先查看版本号

python xxx.py db history

然后记住想要返回的版本号。

返回指定的版本

python xxx.py db downgrade(upgrade) 版本号

然后打开你的代码,可以发现他自动复原了!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python socket C/S结构的聊天室应用实现
Nov 30 Python
python操作gmail实例
Jan 14 Python
深入学习Python中的上下文管理器与else块
Aug 27 Python
运行django项目指定IP和端口的方法
May 14 Python
Python使用Selenium模块模拟浏览器抓取斗鱼直播间信息示例
Jul 18 Python
python实现从pdf文件中提取文本,并自动翻译的方法
Nov 28 Python
Python中PyQt5/PySide2的按钮控件使用实例
Aug 17 Python
python使用beautifulsoup4爬取酷狗音乐代码实例
Dec 04 Python
Python装饰器原理与基本用法分析
Jan 07 Python
python使用pyecharts库画地图数据可视化的实现
Mar 25 Python
matplotlib实现数据实时刷新的示例代码
Jan 05 Python
Python实现老照片修复之上色小技巧
Oct 16 Python
Python定时任务工具之APScheduler使用方式
Jul 24 #Python
Python实现一个带权无回置随机抽选函数的方法
Jul 24 #Python
Django的用户模块与权限系统的示例代码
Jul 24 #Python
python3字符串操作总结
Jul 24 #Python
django数据关系一对多、多对多模型、自关联的建立
Jul 24 #Python
django如何自己创建一个中间件
Jul 24 #Python
django如何通过类视图使用装饰器
Jul 24 #Python
You might like
函数中使用require_once问题深入探讨 优雅的配置文件定义方法推荐
2014/07/02 PHP
php rsa加密解密使用详解
2015/01/14 PHP
Django中的cookie与session操作实例代码
2017/08/17 PHP
php+redis实现商城秒杀功能
2020/11/19 PHP
php使用pthreads v3多线程实现抓取新浪新闻信息操作示例
2020/02/21 PHP
兼容多浏览器的字幕特效Marquee的通用js类
2008/07/20 Javascript
Jquery ajaxsubmit上传图片实现代码
2010/11/04 Javascript
检测jQuery.js是否已加载的判断代码
2011/05/20 Javascript
单击按钮显示隐藏子菜单经典案例
2013/01/04 Javascript
jquery入门—选择器实现隔行变色实例代码
2013/01/04 Javascript
JavaScript禁止页面操作的示例代码
2013/12/17 Javascript
jQuery动画效果图片轮播特效
2016/01/12 Javascript
功能强大的Bootstrap效果展示(二)
2016/08/03 Javascript
vue基于Vue2.0和高德地图的地图组件实例
2017/04/28 Javascript
详解vue.js的devtools安装
2017/05/26 Javascript
浅谈JS中的反柯里化( uncurrying)
2017/08/17 Javascript
JS基于对象的特性实现去除数组中重复项功能详解
2017/11/17 Javascript
JavaScript键盘事件常见用法实例分析
2019/01/03 Javascript
学习python之编写简单乘法口诀表实现代码
2016/02/27 Python
python函数式编程学习之yield表达式形式详解
2018/03/25 Python
解决c++调用python中文乱码问题
2020/07/29 Python
python 如何设置守护进程
2020/10/29 Python
python mongo 向数据中的数组类型新增数据操作
2020/12/05 Python
Rag & Bone官网:瑞格布恩高级成衣
2018/04/19 全球购物
全球领先的美容用品专卖店:Beauty Plus Salon
2018/09/04 全球购物
Myprotein比利时官方网站:欧洲第一运动营养品牌
2020/10/04 全球购物
实习销售业务员自我鉴定
2013/09/21 职场文书
五一家具促销方案
2014/01/10 职场文书
自动化毕业生专业自荐书范文
2014/02/04 职场文书
业务员工作态度散漫检讨书
2014/11/02 职场文书
大二学年个人总结
2015/03/03 职场文书
2015年秋季新学期寄语
2015/03/25 职场文书
交通事故起诉书
2015/05/19 职场文书
2016见义勇为事迹材料汇总
2016/03/01 职场文书
Java 语言中Object 类和System 类详解
2021/07/07 Java/Android
MySQL中的全表扫描和索引树扫描
2022/05/15 MySQL