我有一个带有ManyToMany字段的模型,每当我创建一个对象时,我需要使用之前创建的相同电话或电子邮件在数据库中搜索更多对象。
现在,我正在使用post_save信号执行此操作,但我想知道是否有更好的方法来执行此操作,可能在创建序列化程序上。
class Leads(models.Model):
name = models.CharField(max_lenght=40)
phone = models.CharField(max_lenght=14)
email = models.EmailField()
other_leads = models.ManyToManyField('Leads')
created = models.DateTimeField(auto_now_add)
@receiver(post_save, sender=Leads)
def add_related(sender, instance, created, **kwargs)
if created:
[instance.other_leads.add(lead) for lead in Leads.objects.filter(email=instance.email, created__lt=instance.created)]
有一个信号处理程序是好的。但是,如果你不使用它的值,你应该never use a comprehension for its side effects。只需使用一个共同的循环!没有一条线可以赢得价格,但在可读性,可维护性和空间效率方面存在许多缺点。此外,您可以立即将多个实例传递给add
:
if created:
instance.other_leads.add(*Leads.objects.filter(
email=instance.email,
created__lt=instance.created))