Django 批量更新查询集
示例
假设我们要从id为的作者所有文章中删除2个upvotes51。
仅使用Python这样做会执行N查询(N即queryset中的文章数):
for article in Article.objects.filter(author_id=51):
article.upvotes-= 2
article.save()
# Note that there is a race condition here but this is not the focus
# of this example.如果不是将所有文章都拉入Python,遍历它们,减少投票并将每份更新的文章保存回数据库,该怎么办呢?
使用一个F()表达式,可以在一个查询中做到这一点:
Article.objects.filter(author_id=51).update(upvotes=F('upvotes') - 2)可以在以下SQL查询中进行翻译:
UPDATE app_article SET upvotes = upvotes - 2 WHERE author_id = 51
为什么这样更好?
我们不用Python来完成工作,而是将负载传递到数据库中,并对其进行了微调以进行此类查询。
有效减少实现所需结果所需的数据库查询数量。
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短