Django ORM查询:如何交换属性值?

2022-03-16 00:00:00 python django django-queryset orm

问题描述

这里是一个案例。我想交换用户的值。

user_with_apple = User.objects.filter(fruit=apple)
user_with_pear = User.objects.filter(fruit=pear)

user_with_apple.update(fruit=pear)
user_with_pear.update(fruit=apple)

嗯,这是行不通的,因为一切都以梨告终。我想是因为Django ORM很懒吧?

那么我想问一下,我怎样才能执行这样的"交换"操作呢?我必须使用中间值吗?

非常感谢!

或者,如果我通过对查询进行切片或调用list()来强制计算查询是否有意义? 例如。 user_with_apple=User.objects.filter(水果=苹果)[:] user_with_pear=User.objects.filter(水果=梨)[:]


解决方案

我想到的是:

如果在QuerySet上调用list,则强制Django为您提供对象。这样做的问题是您不能对列表调用update,因此您需要迭代列表,并更新每个对象。

这可能会帮助您上路:

users_with_apple = list(User.objects.filter(fruit=apple))
users_with_pear = list(User.objects.filter(fruit=pear))

for user in users_with_apple:
    user.fruit = pear
    user.save()
for user in users_with_pear:
    user.fruit = apple
    user.save()

相关文章