我正在尝试为我的应用程序上的查询进行正向和反向分页。
我从以下示例开始:https ://developers.google.com/appengine/docs/python/ndb/queries#cursors
我希望该示例执行典型的向前/向后分页以创建可以传递给模板的光标,以便在当前页面之后/之前的后续请求中使用。但它正在做的是为同一页面获取游标,一个从头开始,另一个从结尾(如果我理解正确的话)。
我想要的是指向下一页开头的光标,以及指向上一页开头的光标,以便在我的 UI 中使用。
根据上面提到的例子,我已经设法用下面的代码几乎做到了:
curs = Cursor(urlsafe=self.request.get('cur'))
q = MyModel.query(MyModel.usett == usett_key)
q_forward = q.order(-MyModel.sugerida)
q_reverse = q.order(MyModel.sugerida)
ofus, next_curs, more = q_forward.fetch_page(num_items_page,
start_cursor=curs)
rev_cursor = curs.reversed()
ofus1, prev_curs, more1 = q_reverse.fetch_page(num_items_page,
start_cursor=rev_cursor)
context = {}
if more and next_curs:
context['next_curs'] = next_curs.urlsafe()
if more1 and prev_curs:
context['prev_curs'] = prev_curs.reversed().urlsafe()
问题,以及这个问题的重点,是我使用more
andmore1
来查看是否有下一页。这在倒退的意义上是行不通的。对于第一页,more1
是True
,在第二页more1
是False
,随后的页面给出True
。
我需要False
为第一页和True
其他每一页提供的东西。看起来这个more
返回值是要使用的东西,但也许我有一个错误的查询设置,或者任何其他错误。
感谢大家!
编辑:由于我没有找到一个简单的解决方案,我转而使用ndbpager。