首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Django: queryset.latest('attr').attr性能损失

Django: queryset.latest('attr').attr性能损失
EN

Stack Overflow用户
提问于 2013-10-29 18:45:11
回答 1查看 42关注 0票数 0

出于某种原因,这行代码如下:

代码语言:javascript
复制
val = queryset.latest('attr').attr

工作速度明显慢于:

代码语言:javascript
复制
obj = queryset.latest('attr')
val = obj.attr

在我正在处理的ajax视图中。这种行为出人意料地一致,我想知道幕后是否有任何不好的魔法导致这种性能损失(基准测试为~20秒而不是~2秒)

设置: Django 1.4.3,Python2.7.3,在Windows上通过PyCharm调试

尽管我认为这也会发生在我的Heroku设置上

EN

回答 1

Stack Overflow用户

发布于 2013-10-29 18:53:22

如果您只访问attr一次,那么两个查询之间应该没有任何明显的区别。

但是,请注意以下代码

代码语言:javascript
复制
val = queryset.latest('attr').attr
val = queryset.latest('attr').attr
val = queryset.latest('attr').attr

每次都会从数据库中获取对象,从而导致3次数据库查询。如果将queryset.latest('attr')赋值给一个对象,将只有一个数据库查询。

代码语言:javascript
复制
obj = queryset.latest('attr')
val = obj.attr
val = obj.attr
val = obj.attr
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19655996

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档