1. 程式人生 > 程式設計 >django實現類似觸發器的功能

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實現類似觸發器的功能就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。