0

我想将 ComputedProperty 字段添加到数据存储区中有许多现有实体的模型中。

要查询这个新的 ComputedProperty 上的现有实体,我需要先生成计算属性。

触发计算并将计算值放回数据存储区的最有效方法是什么?

4

2 回答 2

0

取决于您真正拥有多少数据。这是一个任务队列解决方案,但它会消耗你的配额......

class StampValue(webapp.RequestHandler):
    _task_url = '/tasks/stamp'
    _page_size = 100

    @classmethod
    def fire(cls, **params):
        taskqueue.add(url=cls._task_url, params=params)

    def get(self):
        self.fire()

    def post(self):
        key = self.request.get('key')
        if key:
            entities = MyModel.gql('WHERE __key__ >= :1 ORDER BY __key__ ASC', db.Key(key)).fetch(self._page_size+1)
        else:
            entities = MyModel.gql('ORDER BY __key__ ASC').fetch(self._page_size+1)

        key = None
        if len(entities) == self._page_size+1:
            key = str(entities[-1].key())
            self.fire(key=key)
            entities = entities[:self._page_size]

        for entity in entities:
            # update your field here
        db.put(entities)
于 2012-04-22T08:14:31.097 回答
0

取决于您在谈论多少实体。使用MapReduce或简单的远程 API(启动控制台并手动执行)

于 2012-04-22T07:44:12.593 回答