찾다

 >  Q&A  >  본문

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__()方法来执行处理逻辑

但是现在信号无法触发,求问哪里出错了?

怪我咯怪我咯2787일 전526

모든 응답(1)나는 대답할 것이다

  • 阿神

    阿神2017-04-18 10:30:53

    으아악

    위의 수정으로 신호 트리거를 올바르게 캡처할 수 있지만 원리가 무엇인지 모르겠습니다. 쿼리 객체 삭제와 모델 객체 삭제가 레벨 문제인가요? 내장 시그널이 db 레벨 기준인가요?

    회신하다
    0
  • 취소회신하다