python - flask sqlalchemy signals 無法觸發(fā)
問題描述
在我得藍圖當(dāng)中我定義了 一個接受者
# -*- coding: utf-8 -*-from flask_sqlalchemy import models_committed# flag = True# if flag:def on_models_committed(sender, changes): print u’我是訂閱者,我要觸發(fā)任務(wù)’ 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 當(dāng)中的__init__.py 導(dǎo)入了我藍圖中的這個方法
在models.py 中定義了__commit_update__()方法來執(zhí)行處理邏輯
但是現(xiàn)在信號無法觸發(fā),求問哪里出錯了?
問題解答
回答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()
加上以上修改能夠正確的捕捉到信號的觸發(fā)了, 但是不知道原理是啥? query對象的刪除,和model對象的刪除的級別問題么, 內(nèi)置信號是基于db 這一層級別的嗎?
相關(guān)文章:
1. javascript - js中向下取整2. 對mysql某個字段監(jiān)控的功能3. showpassword里的this 是什么意思?代表哪個元素4. mysql優(yōu)化 - mysql EXPLAIN之后怎么看結(jié)果進行優(yōu)化 ?5. html - vue項目中用到了elementUI問題6. html5 - 求詳解h5 video事件監(jiān)聽7. javascript - 原生canvas中如何獲取到觸摸事件的canvas內(nèi)坐標(biāo)?8. JavaScript事件9. mysql scripts提示 /usr/bin/perl: bad interpreter10. python - 為什么正常輸出中文沒有亂碼,zip函數(shù)之后出現(xiàn)中文編程unicode編碼的問題,我是遍歷輸出的啊。
