在Flask里 sqlachemy是非常方便的,但是假如数据量很大的话,后台返回的json速度就很慢,很影响用户体验,所以用
paginate来分页返回数据
paginate(id, num) #id为第几页 num表示一页有几条数据
很明显 我们的页数应该是 [1,sum/num]
所以在前台的页数应该是 1到 数据总数/一页的数据量
例如 有7311条数据,我们需要一页10条数据的话
页数就是 1 ~ 732 因为还有 最后一页 只有一条数据
具体代码:
@home.route('/<int:id>/', methods=['GET'])
def index(id):
if id is None:
id = 1
num = db.session.query(Books).filter(Books.title.ilike("%英语%")).count()
print(num)
pages = db.session.query(Books).filter(Books.title.ilike("%英语%")).paginate(id, 10)
return jsonify(bedict1(pages.items))
def bedict1(a):
lic = []
for item in a:
lic.append(
{
'title': item.title,
'author': item.author,
'info': item.publish,
'id': item.id
}
)
return lic