用flask开发个人博客(22)—— 使用Flask-Migrate实现数据库的更新

        使用Flsak-Migrate数据库迁移框架,可以保证数据库结构在发生变化时,改变数据库结构不至于丢失数据库的数据。使用其进行数据库进行数据库的迁移,主要分为三个步骤:

1 创建数据仓库

        首先我们要在test.py中布置相关环境:

from flask_migrate import Migrate,MigrateCommand
from fask_script import Manager
...
manager=Manager(app)
migrate=Migrate(app,db)
manager.add_command('db',MigrateCommand)

        这里我们引入了Manager模块用来使启动flask时支持命令行。首先,第1行分别引入了migrate模块和Manager相关模块;第4行创建了一个manager对象,以支持自定义命令的配置;第5行创建一个Migrate对象并关联对应的应用程序类对象app和数据库管理类对象db;最后一行将MigrateCommand命令加入到manager对象中,这样就可以在命令行中进行数据库迁移的相关命令.

        需要注意的是,引入Manager支持启动应用程序的命令行时,我们还需要修改app的run语句,改为:

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

        接下来我们使用命令行模式创建一个迁移的仓库:

>>> python test.py db init

        'db'是在manager.add_command('db',MigrateComand)这句中我们声明的命令行对象名称,init是Migrate命令,表示初始化迁移仓库,运行完成之后,会在当前目录下创建一个migrations的文件夹,用于进行迁移的数据库脚本都放在这里.

2 创建迁移脚本

        使用migarate子命令来创建数据库迁移脚本,在此之前我们先改动一下数据库的模型来验证迁移是否成功,我们在User模型中添加age属性:

class User(db.Model):
      __tablename__='users'
      id=db.Column(db.Integer,primary_key=True)
      name=db.Column(db.String(64),unique=True)
      role_id=db.Column(db.Integer,db.ForeignKey('roles.id'))
      age=db.Column(db.Integer)
...
        添加好之后,使用下面的命令自动添加迁移的脚本:

python test.py db migrate -m "inition migrate"

3 更新数据

        使用upgrade和downgrade命令分别向数据库更新数据和从数据库更新数据,使用upgrade命令将本次的改动更新到数据库中:

python test.py db upgrade

        我们检查下是否更新成功:


用flask开发个人博客(22)—— 使用Flask-Migrate实现数据库的更新_第1张图片

        成功进行了更新。


Github位置:
https://github.com/HymanLiuTS/flaskTs

克隆本项目:
git clone g[email protected]:HymanLiuTS/flaskTs.git
获取本文源代码:
git checkout FL22



你可能感兴趣的:(用flask开发个人博客)