line_items 是产品字典以及所需产品的实例数。
我建议不要将其存储在字典中。在关系数据库中,通常将其存储在多条记录的不同表中。这样做的好处是易于查询。例如生成包含某个产品的所有订单的列表,或者包含数量大于 50 的某个产品的列表。
因此我们通常有三个表:
+-------+ 1 N +--------------+ N 1 +---------+
| Order |----------| OrderProduct |----------| Product |
+-------+ +--------------+ +---------+
| email | | quantity |
+-------+ +--------------+
因此我们有三个模型:Order、OrderProduct 和 Product,例如:
Order(models.Model):
email = models.EmailField()
Product(models.Model):
# ...
pass
OrderProduct(models.Model):
order = models.ForeignKey(Order, on_delete=models.CASCADE)
product = models.ForeignKey(Product, on_delete=models.CASCADE)
quantity = models.IntegerField(default=1)
class Meta:
unique_together = ('order', 'product')
因此,我们可以构造如下顺序:
product1 = Product.objects.create()
product2 = Product.objects.create()
my_order = Order.objects.create(email='foo@bar.com')
OrderProduct.objects.create(product=product1, order=my_order)
OrderProduct.objects.create(product=product2, order=my_order, quantity=14)
所以这里我们构造了两个产品和一个订单,我们在这个订单中添加了两个OrderProducts,一个用于product1,一个用于product2,数量为14。