好的,我已经看过了video http://www.google.com/events/io/2011/sessions/more-9s-please-under-the-covers-of-the-high-replication-datastore.html并阅读 App Engine 文档中的文章(包括使用高复制数据存储 http://code.google.com/appengine/docs/python/datastore/hr/overview.html)。然而我仍然对它的实际用法感到完全困惑。我(从视频中)了解了这些好处,而且听起来很棒。但我缺少的是一些实际的例子。网络上有很多主/从示例,但很少说明(带有适当的文档)高复制数据存储。中使用的留言簿代码示例使用高复制数据存储 http://code.google.com/appengine/docs/python/datastore/hr/overview.html文章通过添加前面的留言簿代码示例所没有的新功能来说明祖先键(似乎您可以更改留言簿)。这只会增加混乱。
我经常使用Django 形式 http://code.google.com/appengine/articles/djangoforms.html在 GAE 上,我想知道是否有人可以帮助我将所有这些查询转换为高复制数据存储兼容查询(让我们暂时忘记讨论,并非所有查询都必须是高复制数据存储兼容查询并关注示例本身)。
更新:对于高复制数据存储兼容查询,我指的是始终返回最新数据而不是潜在的陈旧数据的查询。使用实体组似乎是这里的方法,但正如前面提到的,我没有很多关于如何执行此操作的实用代码示例,所以这就是我正在寻找的!
So 本文中的查询 http://code.google.com/appengine/articles/djangoforms.html are:
本文中主要的重复查询是:
query = db.GqlQuery("SELECT * FROM Item ORDER BY name")
我们将其翻译为:
query = Item.all().order('name') // datastore request
验证表单的过程如下:
data = ItemForm(data=self.request.POST)
if data.is_valid():
# Save the data, and redirect to the view page
entity = data.save(commit=False)
entity.added_by = users.get_current_user()
entity.put() // datastore request
从数据存储中获取最新条目以填充表单的情况如下:
id = int(self.request.get('id'))
item = Item.get(db.Key.from_path('Item', id)) // datastore request
data = ItemForm(data=self.request.POST, instance=item)
那么我/我们需要做什么才能使所有这些数据存储请求与高复制数据存储兼容?
最后一件事我也不清楚。使用祖先键,这对数据存储中的模型有任何影响吗?例如,在留言簿代码示例中,他们使用:
def guestbook_key(guestbook_name=None):
return db.Key.from_path('Guestbook', guestbook_name or 'default_guestbook')
然而“留言簿”不存在在模型中 http://code.google.com/p/google-app-engine-samples/source/browse/trunk/guestbook_highrep/guestbook.py#34,那么如何使用 'db.Key.from_path' 以及为什么它会起作用?这是否会改变数据在数据存储中的存储方式,我在检索数据时需要考虑这一点(例如,它是否添加了我在使用 djangoforms 时应该从显示中排除的另一个字段)?
就像我之前说的,这让我很困惑,非常感谢您的帮助!