我在将 GenericRelation
与 update_or_create
结合使用时遇到问题。
我有以下型号:
class LockCode(TimeStampedModel):
context_type = models.ForeignKey(ContentType, on_delete=models.CASCADE)
context_id = models.PositiveIntegerField()
context = GenericForeignKey('context_type', 'context_id')
class Mission(DirtyFieldsMixin, models.Model):
lock_codes = GenericRelation(
LockCode,
content_type_field='context_type',
object_id_field='context_id',
related_query_name='mission'
)
我尝试使用任务作为 key 来创建或更新 LockCode
:
mission = ....
LockCode.objects.update_or_create(
context=mission,
defaults={
#some other columns there
}
而且我有FieldError:字段“上下文”不会生成自动反向关系,因此不能用于反向查询。如果是 GenericForeignKey,请考虑添加 GenericRelation。
当我显式使用 context_id 和 context_type 时它会起作用:
LockCode.objects.update_or_create(
context_id=mission.pk,
context_type=ContentType.objects.get_for_model(Mission),
defaults={
#some other columns there
}
我的配置有问题吗?或者它只是使用 GenericForeignKey
进行 update_or_create 的单一方法?
最佳答案
找到了解决方案。只需要在 update_or_create 中使用 mission
而不是 context
即可:
mission = ....
LockCode.objects.update_or_create(
mission=mission,
defaults={
#some other columns there
}
关于python - update_or_create 的 Django GenericRelation,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56855817/