我想在保存新记录(而不是更新现有记录)时,在Django模型对象的save()方法中触发一个特殊操作。

是检查(self。id != None)有必要且充分地保证自我记录是新的且没有被更新?有没有可能被忽略的特殊情况?


当前回答

我很晚才谈这个话题,但我遇到了自我的问题。当Pk具有与之关联的默认值时,将填充它。

我解决这个问题的方法是在模型中添加一个date_created字段

date_created = models.DateTimeField(auto_now_add=True)

你可以从这里出发

Created = self。date_created为None

其他回答

用pk代替id:

if not self.pk:
  do_something()

自我检查。Id假设Id是模型的主键。更通用的方法是使用pk快捷方式。

Is_new = self。pk为None

要知道您是在更新还是插入对象(数据),请在表单中使用self.instance.fieldname。在表单中定义一个干净的函数,并检查当前值项是否与前一个值项相同,如果不是,则更新它。

自我。Instance和self.instance.fieldname与新值进行比较

检查自我的另一种方法。我们可以检查self。模型的状态

self._state。添加才是真正的创造

self._state。添加是错误的更新

我是从这一页上得到的

对于一个解决方案,即使你有一个UUIDField作为主键(正如其他人所注意到的,如果你只是覆盖save,它也不是None),你也可以插入Django的post_save信号。将此添加到models.py中:

from django.db.models.signals import post_save
from django.dispatch import receiver

@receiver(post_save, sender=MyModel)
def mymodel_saved(sender, instance, created, **kwargs):
    if created:
        # do extra work on your instance, e.g.
        # instance.generate_avatar()
        # instance.send_email_notification()
        pass

这个回调会阻塞save方法,所以你可以做一些事情,比如触发通知或在响应通过网络发送回之前进一步更新模型,无论你是使用表单还是Django REST框架进行AJAX调用。当然,要负责任地使用,并将繁重的任务卸载到作业队列中,而不是让用户等待:)