Django:将具有ForeignKey关系的模型实例保存到数据库的问题

时间:2020-10-04 13:42:57

标签: django django-models foreign-keys

我想使用Django创建和保存模型实例。 这些是我的模型:

class Customer(models.Model):
id = models.IntegerField(primary_key=True, unique=True)
user = models.OneToOneField(User, on_delete=models.CASCADE)
first_name = models.CharField(max_length=255)
last_name = models.CharField(max_length=255)
...

class Order(models.Model):
    id = models.IntegerField(primary_key=True, unique=True)
    customer = models.ForeignKey(Customer, on_delete=models.CASCADE)
    comment = models.TextField()
...

我创建这样的订单:

def store_storage_space_order(cleaned_data):
    try:
        user = User.objects.create_user(
            cleaned_data["customer_email"],
            cleaned_data["customer_email"],
            1234
        )

    customer = Customer.objects.create(
        user=user,
        first_name=cleaned_data["customer_firstname"],
        last_name=cleaned_data["customer_lastname"],
        email=cleaned_data["customer_email"],
        phone_number=cleaned_data["customer_phone"]
    )

    StorageSpaceOrder.objects.create(
        customer=customer,
        order_price=Decimal(cleaned_data["order_price"])
    )

except Exception as exc:
    logger.exception("Couldn't store any order information", exc, cleaned_data)

据我了解,Django也会在调用create时保存对象。

尝试保存订单时,出现以下错误消息:

save() prohibited to prevent data loss due to unsaved related customer

我没有得到什么;客户已经在那里并保存在数据库中。两者之间的客户没有任何变化。

我也尝试过customer_id=customer.id/pk,-但是ID和PK都返回None。

这是为什么,我需要更改什么?再次加载对象不是首选方式,因为我只有将其标记为唯一的ID。

感谢您的输入:)

1 个答案:

答案 0 :(得分:0)

ID字段必须由Django自动生成,因此您无需在模型中声明它们。

如果这样做,则将覆盖创建/保存此模型的实例时调用的默认行为。