sql搜索求总条数

   sql语句:借助count函数求总条数

select count(*) from classify  

可以看到结果集内多了 count(*) 值为7 这一列  ,但这样 取值不能取

 所以起个别名

select count(*) as total from classify

可以通过查询条件进行sql语句的拼接

​​const { query, order = 'asc', field, page = 0, size = 3 } = ctx.query
let sql = 'select * from classify'
let sql2 = 'select count(*)as total from classify'              
    if (query) {

          sql += ` where name like '%${query}%'`              //查询
          sql2 += ` where name like '%${query}%'`              //查询,求总数
     }

    if (field) {

        sql += ` order by ${field} ${order} `               ///在结果集内-排序
    }

    sql += `limit ${page * size},${size}`                     //分页

    const res = await doSQL(sql)
    const res2 = await getOne(sql2)                          //我们只用处理一条数据,所以通过getOne拿到total
    
    ctx.body = { success: true, code: 20000, message: '数据查询成功', data: res, total: res2.total };

res2.total就可以拿到total的值了

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值