对计算属性的NDB查询未正确计算

时间:2015-05-28 10:04:32

标签: python google-app-engine google-cloud-datastore app-engine-ndb

我遇到了一个奇怪的问题。我想我不是replication issue的情况,而是类似的东西。

我的这个模型具有计算属性

   status = ndb.ComputedProperty(lambda self: self._compute_status())
...
    def _compute_status(self):
        if self.canceled:
            return "CANCELED"
        course = self.course.get().course_type
        if course == "SCHEDULED":
            now = datetime.now()
            if now < self.start_date:
                return "UPCOMING"
            elif now > self.end_date:
                return "FINISHED"
        return "ONGOING"

现在,我查询所有模型,然后执行这两个打印

print sessions[0]
print sessions[0].status

结果显示不同的值:

Session(key=Key('Session', 5302669702856704), canceled=False, course=Key('Course', 6605041225957376), created=datetime.datetime(2015, 5, 5, 13, 39, 56, 86329), day_no=None, end_date=datetime.datetime(2015, 5, 8, 9, 35), meta_data=None, name=u'asd', profile=None, session_type=u'JOINT', start_date=datetime.datetime(2015, 5, 7, 8, 50), status='UPCOMING', url=u'', week_no=None)
FINISHED

在第一次打印时,status=ONGOING会在第二次打印FINISHED,因为它应该是end_date今天之后的。{/ p>

这对查询有影响,因为如果我查询status=='FINISHED',它就不会返回正确的结果集。

有什么想法吗?

修改

实际上文档说:

  

警告:ComputedProperties不是基于查询计算的,而是基于   放()。如果更新模型的架构以包含ComputedProperty,   你应该记得通过加载和写入来更新现有的实体   他们到数据存储区。有关更多信息,请参阅更新模型的架构   信息。

但是,我该如何执行查询?我是否可以通过&#34; hand&#34;?

来过滤它们

1 个答案:

答案 0 :(得分:3)

您必须按datetime属性进行查询,因为当您将此实体放入数据存储区时 - 该值是根据当前时间计算的,当您查询它时 - 旧值仍然使用,但值正在增加触摸此属性时重新计算。