Django ORM query: how to swap value of a attribute?(Django ORM查询:如何交换属性值?)
本文介绍了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查询:如何交换属性值?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
织梦狗教程
本文标题为:Django ORM查询:如何交换属性值?
基础教程推荐
猜你喜欢
- Kivy 使用 opencv.调整图像大小 2022-01-01
- Python 中是否有任何支持将长字符串转储为块文字或折叠块的 yaml 库? 2022-01-01
- Python,确定字符串是否应转换为 Int 或 Float 2022-01-01
- 对多索引数据帧的列进行排序 2022-01-01
- matplotlib 设置 yaxis 标签大小 2022-01-01
- 比较两个文本文件以找出差异并将它们输出到新的文本文件 2022-01-01
- kivy 应用程序中的一个简单网页作为小部件 2022-01-01
- 究竟什么是“容器"?在蟒蛇?(以及所有的 python 容器类型是什么?) 2022-01-01
- 在 Python 中将货币解析为数字 2022-01-01
- 在 Django Admin 中使用内联 OneToOneField 2022-01-01
