Nodejs+SQLite分页随笔

目前据我所知有一种办法

即 limit

select * from tablename order by id limit 10 offset 0;

这边有个问题就是如果表中数据过大如1万,那limit 10 offset 9990 可能很消耗时间,如果有这样的数据量也不太建议用SQLite。

这边先将就用limit方法做一个公共类来供自己调用。

分页公共方法需要传入的数据有 SqlStr(SQL语句),OrderBy(排序字段),PageSize(每页显示条数) ,PageIndex(第几页)

传出的数据应该是 ResList(查询结果集),PageCount(总页数)

/*sql分页查询返回对象*/
function limit_res(err, row, pageCount) {
    var err
    var row
    var pageCount
    this.err = err
    this.row = row
    this.pageCount = pageCount
}

const limit_list = async (_db, sqlStr, prams, orderBy, pageSize, pageIndex) => {
    let err
    //先获得totalCount总记录数
    let totalRes = await DB_get(_db, 'SELECT count(*) as count FROM (' + sqlStr + ');', prams)
    if (totalRes.err) {
        err = totalRes.err
    }
    let totalCount = totalRes.row.count
    let pageCount = Math.ceil(totalCount / pageSize)    //计算总页码
    let pageStart = pageIndex * pageSize    //计算起始行
    let nowPageRowCount = pageSize
    if (pageIndex + 1 == pageCount) {   //如果最后一页
        nowPageRowCount = totalCount % pageSize
    }
    sqlStr = sqlStr + ' order by ' + orderBy + ' limit ' + nowPageRowCount + ' offset ' + pageStart + ' ;'
    let r = await DB_All(_db, sqlStr, prams)
    return new limit_res(r.err, r.row, pageCount)
}

module.exports = {limit_list}//暴露

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值