使用SQLAlchemy操作MYSQL黑科技之 event

Posted 青青子衿_MI

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用SQLAlchemy操作MYSQL黑科技之 event相关的知识,希望对你有一定的参考价值。

# coding:utf8
from flask import Flask
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)
#app.config.from_pyfile(‘config‘)
db = SQLAlchemy(app)

app.config[SECRET_KEY] = what s the s
app.config[SQLALCHEMY_DATABASE_URI] = mysql://root:[email protected]:3306/table
app.config[SQLALCHEMY_COMMIT_ON_TEARDOWN] = True
app.config[SQLALCHEMY_TRACK_MODIFICATIONS] = True


temp = 0
class Comment(db.Model):
    __tablename__ = Comment
    id = db.Column(db.Integer, primary_key=True)
    comment = db.Column(db.String(128))
    created = db.Column(db.DateTime, index=True, default=datetime.datetime.utcnow())
    global temp
    pid = db.Column(db.Integer)#, default=temp)
    role_id = db.Column(db.Integer)#, db.ForeignKey(‘Role.id‘))  
    arc_id = db.Column(db.Integer)#, db.ForeignKey(‘Article.id‘))    
    to_role_id = db.Column(db.Integer)

    @staticmethod
    def set_pid(target, value, oldvalue, initiator):
        if not target.to_role_id:              
            global temp                         
            temp += 1
            target.pid = temp
#使用set方法 在传入表单中没有to_role_id的值的时候 自动调用set_id函数,以想要的方式存入数据库
db.event.listen(Comment.arc_id if Comment.to_role_id else Comment.to_role_id,set,Comment.set_pid)   
#当listen的第一个参数为空的时候不执行set_pid函数中的代码 if __name__ == __main__: #db.create_all() 首先创建表单 s = Comment(comment=cscs, role_id=1, arc_id=2) s1 = Comment(comment=cscs, role_id=1, arc_id=2) s2 = Comment(comment=cscs, role_id=2, arc_id=2,to_role_id=1,pid=2) db.session.add(s) db.session.add(s1) db.session.add(s2) db.session.commit()

 


以上是关于使用SQLAlchemy操作MYSQL黑科技之 event的主要内容,如果未能解决你的问题,请参考以下文章

没有Bug的OS内核? 鸿蒙黑科技之操作系统形式验证与安全认证

没有Bug的OS内核? 鸿蒙黑科技之操作系统形式验证与安全认证

Python之Mysql及SQLAlchemy操作总结

Python之Mysql及SQLAlchemy操作总结

Python之Mysql及SQLAlchemy操作总结

Six——tornado操作之用户表单(密码,用户名)数据库迁移使用SQLAlchemy+pymysql配合alembic实现!