Django 批量更新查询集

示例

假设我们要从id为的作者所有文章中删除2个upvotes 51。
仅使用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来完成工作,而是将负载传递到数据库中,并对其进行了微调以进行此类查询。

  • 有效减少实现所需结果所需的数据库查询数量。