Как связать количество с суммой в отношениях "многие ко многим" в Django

В Django у меня есть 2 модели. Одна называется Box и одна называется Product. В коробке может быть много разных продуктов и с разным количеством каждого продукта. Например, box1 может содержать 1 продуктА и 2 продуктаВ.

Моя модель коробки

class Box(models.Model):
    boxName = models.CharField(max_length=255, blank = False)
    
    product = models.ManyToManyField(Product)

    def __str__(self):
        return self.boxName

Моя модель продукта

class Product(models.Model):
        productName = models.CharField(max_length=200)
        productDescription = models.TextField(blank=True)
        productPrice = models.DecimalField(max_digits=9, decimal_places=0, default=0)

    
    class Meta:
        db_table = 'products'
        ordering = ['-productName']

    def __str__(self):
        return self.productName

Как настроить модель, позволяющую выбирать количество товара при создании объекта box?

Определите новую модель, содержащую продукт + количество.

class Box(models.Model):
    boxName = models.CharField(max_length=255, blank = False)
    product_set = models.ManyToManyField(ProductSet)

    def __str__(self):
        return self.boxName

class ProductSet(models.Model):
    quantity = models.PositiveIntegerField()
    product = models.ForeignKey(Product, on_delete = models.PROTECT)

class Product(models.Model):
    productName = models.CharField(max_length=200)
    productDescription = models.TextField(blank=True)
    productPrice = models.DecimalField(max_digits=9, decimal_places=0, default=0)

    
    class Meta:
        db_table = 'products'
        ordering = ['-productName']

    def __str__(self):
        return self.productName
Вернуться на верх