python中的Flask-migrate模块

关于Flask-migrate

  • Flask-Migrate是一个为Flask应用处理SQLAlchemy数据库迁移的扩展,使得可以通过Flask的命令行接口或者Flask-Scripts对数据库进行操作。

配置Flask-migrate

from flask import Flask
from flask_migrate import Migrate, MigrateCommand
from flask_script import Manager
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)

app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root:westos@localhost/Todo'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = True
db = SQLAlchemy(app)

migrate = Migrate(app, db)

manager = Manager(app)
manager.add_command('db', MigrateCommand)

flask-migrate的命令有三个:

python manager.py db init 准备迁移环境
python manager.py db migrate 迁移
python manager.py db upgrade 提交

注:模型有变动时需要在命令行执行 python manager.py db migrate 和 python manager.py db upgrade重新映射到数据库

flask-migrate的使用

1). 创建迁移仓库(migrations目录)

python 练习1.py  db init

1

2). 读取类的内容, 生成版本文件, 并没有真正在数据库中添加或删除;

python  script.py  db migrate -m "版本名后缀"

1

3). 在数据库中增删改, 也就是将迁移应用于数据库;

python script.py  db upgrade

1

4). 检测是否成功?

mysql -uroot -pwestos

1

5). 去查看改变的历史状态;

python script.py db history

1

6). 返回指定的版本状态;降级数据库,不指定版本则是最老版本

python script.py db downgrade base

1

7). 显示当前版本

python data_migrate.py db current

1

8). 升级版本,不指定版本为最新版本

python data_migrate.py db upgrade 版本号

1

9). 帮助,查找所有命令

python data_migrate.py db --help

简单生成迁移仓库

from flask_migrate import MigrateCommand, Migrate
from flask_sqlalchemy import  SQLAlchemy
from flask_script import Manager
from flask import Flask
import pymysql

app = Flask(__name__)
pymysql.install_as_MySQLdb()
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root:westos@localhost/Todo'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = True
# app.config.from_pyfile('./config.py')
db = SQLAlchemy(app)
manager = Manager(app)
migrate = Migrate(app,db)
@manager.command
def dbinit():
    """数据库初始化信息"""
    db.drop_all()
    db.create_all()
    print('数据库初始化成功')
manager.add_command('db', MigrateCommand)
if __name__ == "__main__":
    # 将启动Manger实例接收命令行中的命令。
    manager.run()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值