简体   繁体   中英

Copy Model Object Id From a Model To Another Model In Django

I want to copy data from a model to another model, I found an example Copy Model Object From a Model To Another In Django but I'm getting an error:

AttributeError: 'BigAutoField' object has no attribute 'wid'.

I want wid in the tobjects model to get the Id from w_orders model. This is my code:

models.py

class w_orders(models.Model): 
    Id = models.BigAutoField(primary_key=True)
    datedefwo = models.DateField(default=datetime.now)
    datesched = models.DateField(blank=True, null=True)
    datefinished = models.DateField(blank=True, null=True)
    sign = models.BigIntegerField(blank=True, null=True)
    statusid = models.BigIntegerField(blank=True, null=True, default=1, choices=STATUS_CHOICES)
    typeid = models.BigIntegerField(blank=True, null=True, default=1, choices=TYPE_CHOICES)
    comments = models.CharField(max_length=254, blank=True, null=True)
    navid = models.BigIntegerField(blank=True, null=True)
    navkonsid = models.CharField(max_length=12, blank=True, null=True)
    navname = models.CharField(max_length=254, blank=True, null=True)
    navcustadr = models.CharField(max_length=254, blank=True, null=True)
    navdebt = models.FloatField(blank=True, null=True)
    navpropcode = models.CharField(max_length=254, blank=True, null=True)
    navdepcode = models.CharField(max_length=254, blank=True, null=True)
    navphoneno = models.CharField(max_length=254, blank=True, null=True)
    navreasoncomp = models.CharField(max_length=254, blank=True, null=True)
    nightshift = models.BooleanField(default=False)
    priority = models.BigIntegerField(blank=True, null=True)
    stid = models.BigIntegerField(blank=True, null=True)
    mapurl = models.CharField(max_length=254, blank=True, null=True)

    def __unicode__(self):
        return self.Id

    def save(self, *args, **kwargs):
        super(w_orders, self).save(*args, **kwargs)
        newob = tobjects()
        ...
        newob.save()



class tobjects(models.Model): 
    oid = models.BigAutoField(primary_key=True)
    wid = models.ForeignKey(w_orders, on_delete=models.CASCADE)
    objtypegisid = models.BigIntegerField(blank=True, null=True, default=1)
    objgisid = models.BigIntegerField(blank=True, null=True, default=1)
    condgenid = models.BigIntegerField(blank=True, null=True, default=1)
    condriskid = models.BigIntegerField(blank=True, null=True, default=1)
    condratsid = models.BigIntegerField(blank=True, null=True, default=1)
    condmhcoverid = models.BigIntegerField(blank=True, null=True, default=1)
    condmhwallid = models.BigIntegerField(blank=True, null=True, default=1)
    condpipehydrsid = models.BigIntegerField(blank=True, null=True, default=1)
    condpipehydreid = models.BigIntegerField(blank=True, null=True, default=1)
    condpipedepvolsid = models.BigIntegerField(blank=True, null=True, default=1)
    condpipedepvoleid = models.BigIntegerField(blank=True, null=True, default=1)
    condpipedepconssid = models.BigIntegerField(blank=True, null=True, default=1)
    condpipedepconseid = models.BigIntegerField(blank=True, null=True, default=1)
    txt = models.CharField(max_length=254, blank=True, null=True)

    def __unicode__(self):
        return self.oid
class w_orders(models.Model): 
    Id = models.BigAutoField(primary_key=True)
    datedefwo = models.DateField(default=datetime.now)
    datesched = models.DateField(blank=True, null=True)
    datefinished = models.DateField(blank=True, null=True)
    sign = models.BigIntegerField(blank=True, null=True)
    statusid = models.BigIntegerField(blank=True, null=True, default=1, choices=STATUS_CHOICES)
    typeid = models.BigIntegerField(blank=True, null=True, default=1, choices=TYPE_CHOICES)
    comments = models.CharField(max_length=254, blank=True, null=True)
    navid = models.BigIntegerField(blank=True, null=True)
    navkonsid = models.CharField(max_length=12, blank=True, null=True)
    navname = models.CharField(max_length=254, blank=True, null=True)
    navcustadr = models.CharField(max_length=254, blank=True, null=True)
    navdebt = models.FloatField(blank=True, null=True)
    navpropcode = models.CharField(max_length=254, blank=True, null=True)
    navdepcode = models.CharField(max_length=254, blank=True, null=True)
    navphoneno = models.CharField(max_length=254, blank=True, null=True)
    navreasoncomp = models.CharField(max_length=254, blank=True, null=True)
    nightshift = models.BooleanField(default=False)
    priority = models.BigIntegerField(blank=True, null=True)
    stid = models.BigIntegerField(blank=True, null=True)
    mapurl = models.CharField(max_length=254, blank=True, null=True)

    def __unicode__(self):
        return self.Id




class tobjects(models.Model): 
    oid = models.BigAutoField(primary_key=True)
    wid = models.ForeignKey(w_orders, on_delete=models.CASCADE)
    objtypegisid = models.BigIntegerField(blank=True, null=True, default=1)
    objgisid = models.BigIntegerField(blank=True, null=True, default=1)
    condgenid = models.BigIntegerField(blank=True, null=True, default=1)
    condriskid = models.BigIntegerField(blank=True, null=True, default=1)
    condratsid = models.BigIntegerField(blank=True, null=True, default=1)
    condmhcoverid = models.BigIntegerField(blank=True, null=True, default=1)
    condmhwallid = models.BigIntegerField(blank=True, null=True, default=1)
    condpipehydrsid = models.BigIntegerField(blank=True, null=True, default=1)
    condpipehydreid = models.BigIntegerField(blank=True, null=True, default=1)
    condpipedepvolsid = models.BigIntegerField(blank=True, null=True, default=1)
    condpipedepvoleid = models.BigIntegerField(blank=True, null=True, default=1)
    condpipedepconssid = models.BigIntegerField(blank=True, null=True, default=1)
    condpipedepconseid = models.BigIntegerField(blank=True, null=True, default=1)
    txt = models.CharField(max_length=254, blank=True, null=True)

    def __unicode__(self):
        return self.oid

    @receiver(post_save, sender=w_orders)
    def ensure_order_exists(sender, **kwargs):
        if kwargs.get('created', False):
            tobjects.objects.get_or_create(wid=kwargs.get('instance'))
for o in w_orders.objects.all():
    t = tobjects.create(wid=o)
    t.save()

Also possible is bulk_create which is faster but only works with PostgreSQL (please read https://docs.djangoproject.com/en/dev/ref/models/querysets/#bulk-create ):

tobjects.objects.bulk_create([tobjects(wid=o) for o in w_orders.objects.all()])

Please consider PEP 8 for your code. It's horrible to read.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM