Flask入门之触发器,事件,数据迁移

摘要:
SQLAlchemyCore和SQLAlchemyORM都有各种事件挂钩:核心事件-这些在CoreEvents中描述,包括特定于连接池生命周期、SQL语句执行、事务生命周期以及模式创建和反汇编的事件挂钩。

SQLAlchemy Core和SQLAlchemy ORM都具有各种各样的事件挂钩:

核心事件 - 这些在 Core Events中描述,并包括特定于连接池生命周期,SQL语句执行,事务生命周期以及模式创建和拆卸的事件挂钩。

ORM事件 - 这些在 ORM事件中描述,并且包括特定于类和属性检测,对象初始化钩子,变更钩子,会话状态,刷新和提交钩子,映射器初始化,对象/结果人口和每个事件的事件钩子 - 持久性钩。

二、事件

SQLAlchemy Core和SQLAlchemy ORM都具有各种各样的事件挂钩:

1. 核心事件 - 这些在 Core Events中描述,并包括特定于连接池生命周期,SQL语句执行,事务生命周期以及模式创建和拆卸的事件挂钩。

2. ORM事件 - 这些在 ORM事件中描述,并且包括特定于类和属性检测,对象初始化钩子,变更钩子,会话状态,刷新和提交钩子,映射器初始化,对象/结果人口和每个事件的事件钩子 - 持久性钩。

事件角色预设

#models.py 红色为新增

class Role(db.Model):
    __tablename__ = 'roles'
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String, nullable=True)
    users = db.relationship('User', backref='role')

    @staticmethod
    def seed():
        db.session.add_all(map(lambda r:Role(name=r),['Guests','Administrators']))

监听事件的注册与处理的函数

#models.py 红色为新增

class User(db.Model):
    __tablename__ = 'users'
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String, nullable=True)
    password = db.Column(db.String, nullable=True)
    role_id = db.Column(db.Integer,db.ForeignKey('roles.id'))

    @staticmethod
    def on_created(target,value,initiator):
        target.role=Role.query.filter_by(name='Guests').first()


db.event.listen(User.name,'set',User.on_created)

# listen事件就与on_created这个方法绑定起来

当User新增记录时,调用User.on_created()

三、Flask-Migrate

  当我们到新机子使用时,就要用到数据迁移

  1. 安装

pip install flask-migrate==1.5.0

  2. 导入库

#manager.py 红色为新增

from app import create_app,db
from flask_migrate import Migrate,MigrateCommand

  3. 实例化

migrate=Migrate(app,db)
manager.add_command('db',MigrateCommand)

  4. 数据库初始化(命令行执行)

python manager.py db init

Flask入门之触发器,事件,数据迁移第1张

执行完毕后,会在根目录生成一个 migrations 文件夹

  5. 开始迁移工作

python manager.py db migrate

执行完后,会在 migrations/versions 下生成一个py文件

这个文件里,有两个方法,upgrade()和downgrade()

免责声明:文章转载自《Flask入门之触发器,事件,数据迁移》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇HTML5 本地文件操作之FileSystemAPI整理(一)Spark优化之二:集群上运行jar程序,状态一直Accepted且不停止不报错下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

《游戏引擎架构》笔记六

资源及文件系统 载入及管理多种媒体,是游戏引擎必须具备的能力。多数引擎会采用某种类型的资源(或资产)管理器,载入并管理游戏所需的资源,并确保在同一时间每个媒体文件只可载入一份。每个资源管理器都会大量使用文件系统。本文将介绍现代三维游戏引擎中的各种文件系统API,再分析典型资源管理器的运作方式。 文件系统 文件名和路径 关于文件和文件夹路径的概念,绝对路径和...

mysql 4.0.26 安装流程

引用:http://hi.baidu.com/bdczg/blog/item/e0f475951c8a9f47d0135ef9.html http://www.sudu.cn/info/index.php?op=article&id=114305 MYSQL小档案: 软件版本:4.0.26 软件大小:25.6MB 软件语言:英文版 软件类型:免费软...

收录 Uboot 详解

--------------------------------------------------------------------------------------------------------  我们知道,bootloader是系统上电后最初加载运行的代码。它提供了处理器上电复位后最开始需要执行的初始化代码。     在PC机上引导程序一般...

权值初始化

设计好神经网络结构以及loss function 后,训练神经网络的步骤如下: 初始化权值参数 选择一个合适的梯度下降算法(例如:Adam,RMSprop等) 重复下面的迭代过程: 输入的正向传播 计算loss function 的值 反向传播,计算loss function 相对于权值参数的梯度值 根据选择的梯度下降算法,使用梯度值更新每个权值参数...

Flask入门学习——蓝图Blueprint

flask蓝图可以实现应用程序的模块化,即通常作用于相同的url前缀,eg:/user/id,/user/profile等类似这样,可以放在一个模块当中,这样会让应用更加清晰便于开发与维护。 这里有个例子:(来源:Python web开发实战-董伟明) 模块user.py: from flask import Blueprint bp = Bluepri...

ES之八:ES数据库重建索引——Reindex(数据迁移)

应用背景: 1、当你的数据量过大,而你的索引最初创建的分片数量不足,导致数据入库较慢的情况,此时需要扩大分片的数量,此时可以尝试使用Reindex。 2、当数据的mapping需要修改,但是大量的数据已经导入到索引中了,重新导入数据到新的索引太耗时;但是在ES中,一个字段的mapping在定义并且导入数据之后是不能再修改的, 所以这种情况下也可以考虑尝试使...