Flask 使用 sqlachemy 返回分页的 json 数据 (1ni)

在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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值