IntegrityError UNIQUE约束失败:张贴到Django REST API的OneToOne字段

时间:2018-12-31 04:16:18

标签: python angular django-rest-framework

我要使用Angular 7中开发的webapp作为前端发布到后端Django REST API。基本上,我有两个子类型FacturaFacturaA的超类型模型FacturaE,它们都由OneToOneField关联。

有问题的模型如下:

class Factura(models.Model):
    fecha = models.DateField()
    contrato = models.ForeignKey(Contrato, related_name='facturas', on_delete=models.CASCADE)
    pagado = models.BooleanField(default=False)

def __str__(self):
    return 'Factura %s: %s - %s' % (self.id, self.fecha, self.contrato)

class FacturaE(models.Model):
    factura = models.OneToOneField(
        Factura,
        on_delete=models.CASCADE,
        primary_key=True,
    )
    kwh = models.DecimalField(max_digits=100, decimal_places=2)
    monto = models.DecimalField(max_digits=100, decimal_places=2, null=True, blank=True)

    def save(self, *args, **kwargs):
        #calcula el monto
        if self._state.adding is True:
            self.monto = float(self.kwh) * 4.0588
            super().save(*args, **kwargs)
        super().save(*args, **kwargs)

    class Meta:
        verbose_name = 'Factura Electrica'
        verbose_name_plural = 'Facturas Electricas'

    def __str__(self):
        return 'Electricidad: %s - %s' % (self.factura, self.monto)

在前端应用程序中,我首先通过创建超类型对象Factura进行发布,然后使用添加的键发布FacturaE,如下所示:

  addFactura(fecha: Date, kwh: number, monto: number) {
    this.factura = new Factura(0, fecha, false, this.id);
    this.pagoService.addFactura(this.factura).subscribe(f => {
      this.facturaElectrica = new FacturaEAdd(f.id, kwh, monto);
      this.pagoService.addFacturaElectrica(this.facturaElectrica).subscribe();
    });
  }

在Django Admin中手动添加一个Factura和一个FacturaE不会产生任何错误,但是通过API或通过我的前端应用程序手动执行此操作会给我以下错误。

django.db.utils.IntegrityError: UNIQUE constraint failed: CasadelaAPI_facturae.factura_id

尽管出现此错误,并且尽管返回了500 HTTP状态代码,但是无论我使用哪种方法,该对象仍然会创建。我想知道是什么导致了错误以及如何解决该错误。

编辑:

已解决,supersave()方法覆盖中被调用了两次,后端试图将FacturaE对象保存两次,第二个super().save(*args, **kwargs)则产生了错误

1 个答案:

答案 0 :(得分:1)

错误是因为您通过创建一个OneOnOne并为其分配了一个现有FactoraE对象来违反Factora属性。

因此,代码抛出了Unique constraint failed ...

请检查以下步骤:

  • 请确保您不尝试使用FactoraE对象创建另一个Factora,而该对象已经存在相同的FactoraE项目。

  • p>
  • 也许在您的UI代码中,在服务中(此处未提供)您没有正确传递Factora,因此它与以前的请求相同,从而导致此错误。

    < / li>

更新 不建议两次调用Factora.id,这可能会导致问题。