首页 > 解决方案 > 如何在不克隆数据库关系的情况下克隆模型实例?

问题描述

我正在使用以下代码构建购物车模型。

from django.db import models

class Item(models.Model):
    name = models.CharField(max_length=200)
    price = models.DecimalField(max_digits=8, decimal_places=2)

    def __str__(self):
        return self.name

class Order(models.Model):
    date = models.DateTimeField(auto_now_add=True)
    transcation_id = models.CharField(max_length=200, null=True)

    def __str__(self):
        return str(self.date)

class OrderItem(models.Model):
    item = models.ForeignKey(Item, on_delete=models.CASCADE, blank=True, null=True)
    order = models.ForeignKey(Order, on_delete=models.CASCADE, blank=True, null=True)
    quantity = models.IntegerField(default=0, blank=True, null=True)

Item和之间的多对一关系Order允许一个Order包含多个Item,这看起来很好。

可以简单地克隆模型实例,正如在这个问题中已经回答的那样。

我的问题是,如果priceanItem改变了。订单中包含的项目的价格也发生了变化。但我不希望它被改变。在客户已经购买的情况下,价格不能更改。无论如何要克隆Order与其他模型完全无关的实例吗?

标签: djangodjango-models

解决方案


手动保存价格

class OrderItem(models.Model):
    item = models.ForeignKey(Item, on_delete=models.CASCADE, blank=True, null=True)
    order = models.ForeignKey(Order, on_delete=models.CASCADE, blank=True, null=True)
    quantity = models.IntegerField(default=0, blank=True, null=True)
    price = price = models.DecimalField(max_digits=8, decimal_places=2, null=True, default=None)
    def save():
        if self.pk == None:
            self.price = self.item.price
            super(OrderItem, self).save()

推荐阅读