Google Datastore中的get()无法按预期工作

时间:2016-05-06 10:53:55

标签: python-2.7 google-app-engine google-cloud-datastore

我正在由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()不会造成任何延迟。

1 个答案:

答案 0 :(得分:2)

这是因为GQL查询默认使用的最终一致性。

您需要阅读:

您可以为查询指定read_policy=STRONG_CONSISTENCY,但它具有您应该注意并考虑的相关费用。