因为我的googleappengine python项目有一个非常简单的NDB投影查询,在我的本地机器上可以很好地工作,但是在部署到生产环境中时却神秘地失败了。你知道吗
更神秘的是。。。作为一个测试,我在另一个属性上添加了一个相同的投影,它可以在开发和生产中使用!有人能帮忙吗?!以下是更多细节:
我有以下代表费用的实体:
class Entry(ndb.Model):
datetime = ndb.DateTimeProperty(indexed=True, required=True)
amount = ndb.IntegerProperty(indexed=False, required=True)
payee = ndb.StringProperty(indexed=True, required=True)
comment = ndb.StringProperty(indexed=False)
# ...
在后面的代码中,我正在做一个投影条目.收款人(获取所有收款人的列表)。作为测试,我还添加了一个投影Entry.datetime地址:
log_msg = '' # For passing debug info to the browser
payeeObjects = Entry.query(ancestor=exp_traq_key(exp_traq_name), projection=[Entry.payee]).fetch()
payees = []
for obj in payeeObjects:
payees.append(obj.payee)
log_msg += '%d payees: %s' % (len(payees), str(payees))
log_msg += ' ------------------- ' # a visual separator
dtObjects = Entry.query(ancestor=exp_traq_key(exp_traq_name), projection=[Entry.datetime]).fetch()
dts = []
for obj in dtObjects:
dts.append(obj.datetime)
log_msg += '%d datetimes: %s' % (len(dts), str(dts))
#...other code, including passing log_msg down to the client
下面是dev环境中的输出(注意,控制台中显示了收款人列表和日期时间列表):
这是部署到appengine时的输出。我无法让它返回收款人名单。它不断返回一个空列表,即使在dev中它返回的列表很好:
我已经确保在GAE上正确设置了索引:
请帮帮我!你知道吗
2018-12-05更新: 我在制作中又加了几个条目,他们被选中了!请参见屏幕截图。但旧的条目仍然没有被退回。
我的直接反应是需要以某种方式“刷新”数据存储索引,以便它可以“看到”旧条目。但问题是我昨天删除并重新创建了索引,这意味着它应该有旧的条目。。。所以仍然需要帮助解开这个谜!你知道吗
我想出来了。该死,这根本不是直觉。我希望GAE文档在这一点上更好。。。你知道吗
我在生产中的数据存储包含许多以前创建的条目。作为我最新代码的一部分,我试图在上面做投影条目.收款人,我不得不改变条目.收款人从未索引到索引,如下所示:
因此,现在投影查询会忽略数据存储中的所有条目,因为paye上的索引会忽略这些条目。你知道吗
所以我现在需要做的是以某种方式将所有这些旧实体迁移到index=True。你知道吗
更新-下面是我如何进行迁移的。结果比预期的简单。你知道吗
这是通过将所有条目读入更新的数据结构(其中条目.收款人是indexed=True),并将其写回数据存储,以便实体现在将被索引。你知道吗
相关问题 更多 >
编程相关推荐