django實現類似觸發器的功能
這篇部落格給大家講解在django中類似觸發器的效果
這篇教程分別會講解
插入記錄後,刪除記錄前,刪除記錄後這三個部分
相關環境 python 3.6 django2.0
我們一起來看看需求
有一個部落格模型 ,有一個 部落格計數模型
現在的需求是每要建立一個部落格,就把部落格計數模型中的計數字段初始化為0,我們不禁想到了觸發器
在建立完blog記錄後,我們就對應著在部落格計數表上進行相關操作。
一起來看看部落格計數模型
再來看看部落格模型
可以看到,在產生模型例項(即資料庫表產生新紀錄)的時候,重寫父類模型中的save方法,在save方法中建議先呼叫一次save方法,將記錄寫在資料表中,再去自定義實現自己拓展的功能
好了 插入記錄的觸發器效果我們完成了,再來看看刪除記錄的觸發器效果該如何實現
我們現在仍然有一個需求,為了保持資料庫的一致性,我們希望在刪除部落格之前,先將該部落格下的評論都刪除,再將該部落格刪除
看看我們的評論模型
這個時候就不能像save()方法那樣,解決方案是在models.py中進行相關操作,在刪除之前傳送一個訊號,將該部落格記錄傳給該方法
這裡的形參instance即為接受的部落格模型例項
from django.db.models.signals import post_save,post_delete,pre_delete from django.dispatch import receiver @receiver(pre_delete,sender=Blog) def before_delete_blog(sender,instance,**kwargs): print( instance.title + " has been deleted ")#測試程式碼 class ReadNum(models.Model): count = models.IntegerField(default = 0) blog = models.OneToOneField(Blog,on_delete = models.CASCADE) def __str__(self): return self.blog.title class Meta: #ordering = ['-created_time'] verbose_name = '部落格計數' verbose_name_plural = '部落格計數'
我們對應著進行一下測試:
可見我們已經達成了目的,當然,這裡的僅僅是一個測試的程式碼,大家可以根據業務需且能自定義相關操作。
總結:
好,到這裡就給大家介紹了django下,實現類似觸發器的效果,觸發insert操作,重寫模型下的save方法
觸發delete方法 用到django訊號機制 django刪除該記錄前後會發送訊號,捕捉這一訊號,可以定製自己的操作,實現類似觸發器的效果,感謝大家
以上這篇django實現類似觸發器的功能就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。