目前据我所知有一种办法
即 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}//暴露