GAE-python-NDB投影查询在开发中工作,但不在生产中

2024-09-20 05:28:18 发布

您现在位置:Python中文网/ 问答频道 /正文

因为我的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环境中的输出(注意,控制台中显示了收款人列表和日期时间列表):

enter image description here

这是部署到appengine时的输出。我无法让它返回收款人名单。它不断返回一个空列表,即使在dev中它返回的列表很好:

enter image description here

我已经确保在GAE上正确设置了索引:

enter image description here

请帮帮我!你知道吗


2018-12-05更新: 我在制作中又加了几个条目,他们被选中了!请参见屏幕截图。但旧的条目仍然没有被退回。 enter image description here

我的直接反应是需要以某种方式“刷新”数据存储索引,以便它可以“看到”旧条目。但问题是我昨天删除并重新创建了索引,这意味着它应该有旧的条目。。。所以仍然需要帮助解开这个谜!你知道吗


Tags: logtrueobj列表datetime条目msgindexed
1条回答
网友
1楼 · 发布于 2024-09-20 05:28:18

我想出来了。该死,这根本不是直觉。我希望GAE文档在这一点上更好。。。你知道吗

我在生产中的数据存储包含许多以前创建的条目。作为我最新代码的一部分,我试图在上面做投影条目.收款人,我不得不改变条目.收款人从未索引到索引,如下所示:

payee = ndb.StringProperty(indexed=True, required=True) # Originally was indexed=False

因此,现在投影查询会忽略数据存储中的所有条目,因为paye上的索引会忽略这些条目。你知道吗

所以我现在需要做的是以某种方式将所有这些旧实体迁移到index=True。你知道吗


更新-下面是我如何进行迁移的。结果比预期的简单。你知道吗

def runPayeeTypeMigration(exp_traq_name):
  Entry.query(ancestor=exp_traq_key(exp_traq_name)).fetch()
  for entry in entries:
    entry.put()

这是通过将所有条目读入更新的数据结构(其中条目.收款人是indexed=True),并将其写回数据存储,以便实体现在将被索引。你知道吗

相关问题 更多 >