django

2016-03-22 14 views
0

numaralı ürüne ait özel birleşik birincil anahtar oluşturun Bir faturalandırma yazılımı planlıyorum. Şimdi, faturalar için, birincil anahtar olmak istediğim bir fatura-no'ya ihtiyacım var. Bu fatura no, müşteri kimliği ve otomatik artım seri no. Müşteri kimliği "ABC" isedjango

ex, o zaman bu yapılabilir Nasıl

Django olduğunu .... fatura pk vs vs ABC1, ABC2, olmak istiyorum. Şu anda sqlite kullanıyorum, ancak dağıtım sırasında MySQL kullanmayı planlıyorum.

Teşekkür ederiz.

cevap

2

Özelleştir yöntemi kaydetmek ve oluşturmak birincil anahtar

def sku(last_sku): 
    sku = last_sku[:4] 
    sku += str(int(last_sku[4:]) + 1).zfill(4) 
    return sku; 

class YourModel(models.Model): 
    sku = models.CharField(max_length=8,primary_key==True) 
    customer = models.ForeignKey(Customer) 
    ... 

    def save(self, *args, **kwargs): 
     if not self.sku: 
      customer_id = self.customer.id 
      try: 
       last = YourModel.objects.filter(customer_id = customer_id).latest('sku') 
       self.sku = sku(last.sku) 
      except YourModel.DoesNotExist: 
       self.sku = self.customer_id+"0001" 
     super(YourModel,self).save(*args,**kwargs)