我在以一对一关系保存反向对象时遇到问题。根据 Django 文档,一旦使用 save() 方法( https://docs.djangoproject.com/en/1.9/topics/db/examples/one_to_one/ ),一切都会正常工作。
但是我的情况有所不同:
class A(models.Model):
name = models.CharField(max_length=30)
class B(models.Model):
name = models.CharField(max_length=30)
aObject = models.OneToOneField(A, on_delete=models.SET_NULL, null=True, blank=True)
我首先创建多个 B 对象并将它们保存到数据库中。然后我创建多个 A 对象,将它们映射到相应的 B 对象。然后我使用bulk_create()保存A对象,最后使用save()保存修改后的B对象。
我收到错误:
ValueError: save() prohibited to prevent data loss due to unsaved related object 'aObject'.
似乎在 A 对象上使用bulk_create 不会执行 save() 会执行的一些操作。
我该如何解决这个问题? (出于性能原因,我需要使用bulk_create)
谢谢
最佳答案
当您使用bulk_create
时,Django不会获取新对象的主键。因此,无法将新对象用作一对一字段、多对多字段或外键的值。
Django 1.10 将支持为 PostgreSQL 使用 bulk_create()
创建的对象设置主键。在那之前,对于其他数据库后端,恐怕你运气不好。
参见the docs了解更多信息。
关于python - Django一对一字段反向更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36082136/