作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
澄清一下,我有数千个属性项,每个项都有一个“当前”字段(以及其他字段)。要重置系统以便再次使用,我需要将每个项目的“属性”字段设置为 false。现在,当然有一个简单的方法来做到这一点,就是:
for obj in Property.objects.all():
obj.present = False
obj.save()
但这在我的开发服务器上花费了将近 30 秒。我觉得一定有更好的方法,所以我尝试使用 Django 的 only
查询集来限制加载的字段:
for obj in Property.objects.only('present'):
obj.present = False
obj.save()
无论出于何种原因,这实际上比获取整个对象花费的时间更长。
因为我需要不加选择地将这些值全部设置为False,有没有更快的方法?除了“go do it”命令外,此函数不接受任何用户输入,因此我认为 native SQL 命令是一个安全的选择,但我对 SQL 的了解不足以起草这样的命令。
谢谢大家
最佳答案
使用 update
查询:
Property.objects.all().update(present=False)
请注意,update()
查询在 SQL 级别运行,因此如果您的模型具有自定义的 save()
方法,则不会在此处调用它。在这种情况下,您使用的普通 for 循环版本是可行的方法。
关于python - 如何一次快速设置 Django 模型的所有实例的字段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25533837/
我是一名优秀的程序员,十分优秀!