Django ORM查询:如何交换属性值? [英] Django ORM query: how to swap value of a attribute?

查看:33
本文介绍了Django 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()

这篇关于Django ORM查询:如何交换属性值?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆