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来完成工作,而是将负载传递到数据库中,并对其进行了微调以进行此类查询。
有效减少实现所需结果所需的数据库查询数量。
以上是 Django 批量更新查询集 的全部内容, 来源链接: utcz.com/z/343154.html