django实现类似触发器的功能
作者:qq_40157234 发布时间:2023-10-10 22:36:41
这篇博客给大家讲解在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删除该记录前后会发送信号,捕捉这一信号,可以定制自己的操作,实现类似触发器的效果,感谢大家
来源:https://blog.csdn.net/qq_40157234/article/details/80691348
猜你喜欢
- selenium操作chrome浏览器需要有ChromeDriver驱动来协助。webdriver中关浏览器关闭有两个方法,一个叫quit,
- 一 方法汇总在 Python 进程中,有几种方法可以实现数据交互:共享内存:这是一种用于进程间通信的高效方式。多个进程可以访问同一个共享内存
- 但有时候,需要当某事件触发时,我们先做一些操作,然后再跳转,这时,就要用JAVASCRIPT来实现这一跳转功能。 下面是具体的做法: 一:跳
- pyquery库是jQuery的Python实现,可以用于解析HTML网页内容,使用方法:from pyquery import PyQue
- leaflet为R语言提供了API很好用,这次尝试用Python使用leaflet,需要folium安装foliumpip install
- 1、使用字符串函数replace>>> a = 'hello world'>>> a.r
- 项目开发中,代码管理肯定离不开git操作,Pycharm中没有复杂的命令操作,只需要进行一些简单的菜单操作就可以方便的实现版本管理,下面分别
- 如下所示:import picklewith open(filename, 'rb') as f: datadict = p
- 本文实例讲述了PHP实现的简单排列组合算法应用。分享给大家供大家参考,具体如下:一、问题:给你一个40斤的西瓜,给3个人分,有多少种分法?二
- 创建游戏文件 2048.py首先导入需要的包:import cursesfrom random import randrange, choi
- 前言利用Django开发网站,可以设计出非常优美的url规则,如果url的匹配规则(包含正则表达式)组织得比较好,view的结构就会比较清晰
- 如果只是想实现将jenkins的构建结果发送到企业微信进行通知,最简便的方式是安装Qy Wechat Notification Plugin
- 本文介绍的圆角方法很特别,有创意。昨天群里大家讨论到一个豆瓣上的按钮,下面这个。在这里用到了不同宽度的按钮,但是只是用到了一个图片。&nbs
- 规律:半角空格的 charCode 为 32, 全角空格为 12288. 其他半角字符 ( 33 – 126 ) 与全角 ( 65281 –
- 场景游戏里有很多关卡(可能有几百个了),理论上每次发布到外网前都要遍历各关卡看看会不会有异常,上次就有玩家在打某个关卡时卡住不动了,如果每个
- 1.安装依赖包 pip install channels channels-redis2.settings.py 修改加上支持INSTALL
- 有时需要根据项目的实际需求向spider传递参数以控制spider的行为,比如说,根据用户提交的url来控制spider爬取的网站。在这种情
- 本文实例讲述了Python决策树和随机森林算法。分享给大家供大家参考,具体如下:决策树和随机森林都是常用的分类算法,它们的判断逻辑和人的思维
- Socket 套接字:通讯端点 简介socket起源于Unix,而Unix/Linux基本哲学之一就是“一切皆文件”,对于文件用【打开】【读
- 1.INSERT INTO SELECT语句 语句形式为:Insert into Table2(field1,field2,...) sel