python - flask sqlalchemy signals 无法触发
问题描述
在我得蓝图当中我定义了 一个接受者
# -*- coding: utf-8 -*-from flask_sqlalchemy import models_committed# flag = True# if flag:def on_models_committed(sender, changes): print u’我是订阅者,我要触发任务’ for obj, change in changes:if change == ’insert’ and hasattr(obj, ’__commit_insert__’): obj.__commit_insert__()elif change == ’update’ and hasattr(obj, ’__commit_update__’): obj.__commit_update__()elif change == ’delete’ and hasattr(obj, ’__commit_delete__’): obj.__commit_delete__()models_committed.connect(on_models_committed)
然后哦在create_app 当中的__init__.py 导入了我蓝图中的这个方法
在models.py 中定义了__commit_update__()方法来执行处理逻辑
但是现在信号无法触发,求问哪里出错了?
问题解答
回答1:问题解决方式db.session.query(ClassModel).filter( ClassModel.id == ids).delete()修改成db.session.query(ClassModel).filter( ClassModel.id == ids).first().delete()classModel(db.Model): .....def delete(self):db.session.delete(self)db.session.commit()
加上以上修改能够正确的捕捉到信号的触发了, 但是不知道原理是啥? query对象的删除,和model对象的删除的级别问题么, 内置信号是基于db 这一层级别的吗?
相关文章:
1. javascript - 数组原声方法中的一段代码2. html - eclipse 标签错误3. 求大神帮我看看是哪里写错了 感谢细心解答4. php自学从哪里开始?5. javascript - 怎么实现移动端页面滑动切换,从1可以滑到2 但是不能从2滑回1 这样的效果呢?6. javascript - JS设置Video视频对象的currentTime时出现了问题,IE,Edge,火狐,都可以设置,反而chrom却...7. 数据库 - MySQL 单表500W+数据,查询超时,如何优化呢?8. mysql多表查询9. phpstady在win10上运行10. javascript - 如果所有请求都放到actions 里面,那拿到的数据应该 放在哪里,state 还是vue实例里面的data?
