我遇到了一个奇怪的问题。我想我不是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;?
来过滤它们答案 0 :(得分:3)
您必须按datetime属性进行查询,因为当您将此实体放入数据存储区时 - 该值是根据当前时间计算的,当您查询它时 - 旧值仍然使用,但值正在增加触摸此属性时重新计算。