【发布时间】:2010-06-11 04:21:16
【问题描述】:
我见过这样的查询:
user = User.objects.all() or User.objects.filter(username = username)
即使我们不需要所有列,也会获取表的所有列。我们有更好的方法来编写数据库查询吗?如果是,为什么我们不经常看到该代码?
【问题讨论】:
我见过这样的查询:
user = User.objects.all() or User.objects.filter(username = username)
即使我们不需要所有列,也会获取表的所有列。我们有更好的方法来编写数据库查询吗?如果是,为什么我们不经常看到该代码?
【问题讨论】:
QuerySet.only() 和 QuerySet.defer() 可用于优化 ORM 将提取哪些字段,将其他字段推迟到模型上的适当属性被访问。
【讨论】:
使用 django 1.8: 使用 values_list
Entry.objects.values_list('id', 'headline')
【讨论】:
如果您只需要作为字典的值,请使用 objects.values('')。它也更快。
参见文档:http://docs.djangoproject.com/en/dev/ref/models/querysets/#values-fields
【讨论】: