我正在由Steve Hoffman在Udacity上的Web Development课程中构建一个基本博客。这是我的代码 -
import os
import webapp2
import jinja2
from google.appengine.ext import db
template_dir = os.path.join(os.path.dirname(__file__), 'templates')
jinja_env = jinja2.Environment(loader = jinja2.FileSystemLoader(template_dir), autoescape = True)
def datetimeformat(value, format='%H:%M / %d-%m-%Y'):
return value.strftime(format)
jinja_env.filters['datetimeformat'] = datetimeformat
def render_str(template, **params):
t = jinja_env.get_template(template)
return t.render(params)
class Entries(db.Model):
title = db.StringProperty(required = True)
body = db.TextProperty(required = True)
created = db.DateTimeProperty(auto_now_add = True)
class MainPage(webapp2.RequestHandler):
def get(self):
entries = db.GqlQuery('select * from Entries order by created desc limit 10')
self.response.write(render_str('mainpage.html', entries=entries))
class NewPost(webapp2.RequestHandler):
def get(self):
self.response.write(render_str('newpost.html', error=""))
def post(self):
title = self.request.get('title')
body = self.request.get('body')
if title and body:
e = Entries(title=title, body=body)
length = db.GqlQuery('select * from Entries order by created desc').count()
e.put()
self.redirect('/newpost/' + str(length+1))
else:
self.response.write(render_str('newpost.html', error="Please type in a title and some content"))
class Permalink(webapp2.RequestHandler):
def get(self, id):
e = db.GqlQuery('select * from Entries order by created desc').get()
self.response.write(render_str('permalink.html', id=id, entry = e))
app = webapp2.WSGIApplication([('/', MainPage),
('/newpost', NewPost),
('/newpost/(\d+)', Permalink)
], debug=True)
在班级Permalink
中,我在查询中使用get()
方法,而不是按照创建的降序返回所有记录。因此,它应该返回最近添加的记录。但是当我尝试添加新记录时,permalink.html
(它只是显示标题,正文和新条目创建日期的页面)显示最近添加的SECOND。例如,我已经有三条记录,所以当我添加第四条记录时,permalink.html
没有显示第四条记录的详细信息,而是显示了第三条记录的详细信息。我做错了吗?
我认为我的问题与此重复 - Read delay in App Engine Datastore after put()。这个问题是关于put()
的阅读延迟,而我正在使用get()
。接受的答案还指出get()
不会造成任何延迟。
答案 0 :(得分:2)
这是因为GQL查询默认使用的最终一致性。
您需要阅读:
您可以为查询指定read_policy=STRONG_CONSISTENCY
,但它具有您应该注意并考虑的相关费用。