首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Google-app-engine NDB iter keys_only

Google-app-engine NDB iter keys_only
EN

Stack Overflow用户
提问于 2012-04-01 22:37:36
回答 2查看 1.3K关注 0票数 4

假设我有一个经常执行的查询,很可能会产生相同的结果。

使用:

代码语言:javascript
复制
for key in qry.iter(keys_only=True):
    item = key.get()
    #do something with item

将比以下各项性能更好:

代码语言:javascript
复制
for item in qry:
    #do something with item

因为在第一个示例中,查询将只加载键,并且对key.get()的后续调用将利用NDB的缓存机制,而示例2将始终从存储中获取实体?还是我误解了什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-04-02 11:57:13

我怀疑第二种形式的性能会更好--值不在缓存中总是有可能的,然后,假设您得到的是多个实体,那么您将进行多次往返。这很快就会变得更慢。

一种更好的方法确实如http://code.google.com/p/appengine-ndb-experiment/issues/detail?id=118所示--使用ndb.multi_get(q.fetch(keys_only=True))。但是,如果缓存命中率太低,情况会更糟;这一点在这个问题中有广泛的讨论。

票数 7
EN

Stack Overflow用户

发布于 2012-04-01 23:08:11

AFAIK它不会有任何不同,因为在内部,ndb缓存一切,包括查询。如果你打算用每一个都做其他的事情,试试异步api。这可以节省宝贵的时间。编辑:此外,如果ndb提前知道查询,它甚至可以预取它们。

我在六个月前读过这篇文章,所以我不确定什么是当前的行为。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9965204

复制
相关文章

相似问题

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