当我更新GAE数据存储时,只有在浏览器刷新页面后,才会显示正确的数据存储内容:
import os
from google.appengine.ext.webapp import template
from google.appengine.ext import db
import webapp2
#def testkey():
# return db.Key.from_path('test', 'test')
class TestEntity(db.Model):
testkey = db.StringProperty(multiline=False)
testvalue = db.StringProperty(multiline=False)
class TestRefreshProblem(webapp2.RequestHandler):
def get(self):
testquery = TestEntity.all()#.ancestor(testkey())
entities = testquery.run()
template_values = {
'entities': entities,
}
path = os.path.join(os.path.dirname(__file__), 'index.html')
self.response.out.write(template.render(path, template_values))
class TestRefreshProblemPost(webapp2.RequestHandler):
def post(self):
# testEntity = TestEntity(parent=testkey())
testEntity = TestEntity()
testEntity.testkey = self.request.get('testkey')
testEntity.testvalue = self.request.get('testvalue')
testEntity.put()
self.redirect('/')
app = webapp2.WSGIApplication([
('/', TestRefreshProblem),
('/pst', TestRefreshProblemPost)
], debug=True)
index.html是:
<html>
<body>
<table border=0>
<tr><td width=200>Key</td><td width=200>Value</td></tr>
{% for entity in entities %}
<tr>
<td width=200>{{ entity.testkey|escape }}</td>
<td width=200>{{ entity.testvalue|escape }}</td>
</tr>
{% endfor %}
</table>
<form action="/pst" method="post">
<table>
<td ><input type="text" name="testkey" size=30/></td>
<td ><input type="text" name="testvalue" size=30/></td>
<tr><td><input type="submit" value="Add entity"></td></tr>
</table>
</form>
</body>
</html>
这个问题通过使用(伪)祖先(re:带有#的行)而消失。在我看来这是一种奇怪的行为。。。没有祖先能解决吗?
最佳答案
这是预期的行为,因为eventual consistency。
实际上,因为您运行的是开发服务器,所以这只是对最终一致性的模拟—在实际的生产系统中,结果不会很容易预测。但解决办法是一样的。
关于python - GAE数据存储区不刷新,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/16022165/