zoukankan      html  css  js  c++  java
  • Flask入门之触发器,事件,数据迁移

    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

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

      5. 开始迁移工作

    python manager.py db migrate

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

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

  • 相关阅读:
    人人开源框架学习笔记
    Gitea安装笔记
    使用sdk方式获取微信的用户信息
    重写java类的equals()和hashCode方法
    Mysql 实现分页功能
    位运算应用和解析
    java代码POST方式请求SOAP
    java实现文件拷贝
    动态创建线程(多线程)处理大量数据
    ActiveMQ监听者接收信息
  • 原文地址:https://www.cnblogs.com/wongbingming/p/6833407.html
Copyright © 2011-2022 走看看