python - flask sqlalchemy signals 無(wú)法觸發(fā)
問(wèn)題描述
在我得藍(lán)圖當(dāng)中我定義了 一個(gè)接受者
# -*- 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)入了我藍(lán)圖中的這個(gè)方法
在models.py 中定義了__commit_update__()方法來(lái)執(zhí)行處理邏輯
但是現(xiàn)在信號(hào)無(wú)法觸發(fā),求問(wèn)哪里出錯(cuò)了?
問(wèn)題解答
回答1:問(wèn)題解決方式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()
加上以上修改能夠正確的捕捉到信號(hào)的觸發(fā)了, 但是不知道原理是啥? query對(duì)象的刪除,和model對(duì)象的刪除的級(jí)別問(wèn)題么, 內(nèi)置信號(hào)是基于db 這一層級(jí)別的嗎?
相關(guān)文章:
1. 我在centos容器里安裝docker,也就是在容器里安裝容器,報(bào)錯(cuò)了?2. docker內(nèi)創(chuàng)建jenkins訪問(wèn)另一個(gè)容器下的服務(wù)器問(wèn)題3. 在windows下安裝docker Toolbox 啟動(dòng)Docker Quickstart Terminal 失敗!4. docker不顯示端口映射呢?5. docker-compose中volumes的問(wèn)題6. golang - 用IDE看docker源碼時(shí)的小問(wèn)題7. 關(guān)docker hub上有些鏡像的tag被標(biāo)記““This image has vulnerabilities””8. docker容器呢SSH為什么連不通呢?9. javascript - 連續(xù)點(diǎn)擊觸發(fā)mouseleave事件10. mac里的docker如何命令行開(kāi)啟呢?

網(wǎng)公網(wǎng)安備