在Django中保存重复的记录

时间:2014-10-20 21:19:46

标签: django django-models django-forms

我开始学习django,我有这个新手问题: 我必须模型化模型之间的关系是一对多的。一个提供者必须有许多DetailLoad。

我为DetailLoad创建了一个表单,我只需要保存id_proveedor(FK),anio和mes。 但是当我尝试保存表单时,会显示验证错误“详细信息此供应商的加载已存在”

Models.py

    class Provider(models.Model):
        id_proveedor = models.AutoField(primary_key=True, db_column='id_proveedor')
        nombre = models.CharField(max_length=50, blank=True)
        tipo = models.CharField(max_length=50, blank=True)
        asignado_a = models.CharField(max_length=15, blank=True, verbose_name='Asignado a')
        moneda = models.CharField(max_length=1, blank=True)
        class Meta:
            managed = False
            db_table = 'mpc_proveedores'

        def __unicode__(self):
            return self.nombre

class DetailLoad(models.Model):
    id_proveedor = models.ForeignKey(Proveedor,db_column='id_proveedor', primary_key=True, verbose_name='Proveedor')
    anio = models.IntegerField(blank=True, null=True)
    mes = models.IntegerField(blank=True, null=True)
    f_carga = models.DateField(blank=True, null=True, verbose_name='Fecha de carga')
    usuario = models.CharField(max_length=15, blank=True)
    registros = models.FloatField(blank=True, null=True,verbose_name='Cant. de Registros')
    num_codigos = models.IntegerField(blank=True, null=True,verbose_name='Cant. codigos')
    lista_codigos = models.CharField(max_length=2500, blank=True, verbose_name='Lista de Codigos')
    class Meta:
        managed = False
        db_table = 'mpc_detalle_carga_archivo'

我用来保存数据的表单的定义:

class NewDetLoadForm(forms.ModelForm):
      def __init__(self,*args,**kwargs):
       super(NewDetRecForm,self).__init__(*args,**kwargs)
       self.helper = FormHelper(self)
       self.helper.layout.append(Submit('save','Grabar'))
       self.helper.layout = Layout(
        Fieldset('',
                 'id_proveedor',
                 'anio',
                 'mes',
                 Submit('save','Grabar'),
                )
       )


      class Meta:
        model = DetalleRecepcion

我的观点:

def NewDetLoadView(request):
    if request.method == "POST":
       drform = NewDetLoadForm(request.POST or none)
       if drform.is_valid():
          drform.save()
          return HttpResponseRedirect('/monitor/')
    else:
       drform = NewDetLoadForm()

    return render_to_response('newdetload.html',locals(),
                               context_instance=RequestContext(request))

我需要能够保存记录,选择提供者并填写其他两个字段,即使是重复的行。 顺便说一下,遗留数据库,表没有约束或任何关系的另一个表。

提前致谢

1 个答案:

答案 0 :(得分:1)

DetailLoad模型中,您设置了Proveedor ForeignKey并将其作为主键。主键始终是唯一的,这就是您无法添加其他条目的原因。您需要从

中删除primary_key=True
id_proveedor = models.ForeignKey(Proveedor,db_column='id_proveedor', primary_key=True, verbose_name='Proveedor')

在django中,主键是自动生成的,您不需要在模型中定义它们。可以使用idpk属性访问主键。