PageHelper分页查询逻辑算法详解+偏移量查询公式

基本逻辑算法

public class PageGelper{
    publicstatic void main(String[] args){
/*一共42条数据, 每页要求有10条数据 , 请问能分成几页?*/

int totalcount = 42 ; //定义共有多少条数据
int pagesize = 10 ;   //定义每页多少条数据

        // 共分几页 = 总条数%(取余)每页条数 ? 总条数/总页数 : 总条数/总页数 + 1 
        // 因为int整形运算不会计算小数部分
int number = totalcount % pagesize == 0 ? totalcount / pagesize : totalcount /pagesize + 1 ; //(利用三目运算计算,?前代码为true走:前,为false走:后)
        
System.out.println(number);//算出来一共5页;

  


//一共5页,如何求当前此页的上一页和下一页?

//上一页:
int currentPage = 3 ; //定义一个当前页码
int prevpage = currentPage - 1 >= 1 ?currentPage - 1 : 1 ; //求上一页的.(利用三目运算计算)
System.out.println(prevpage);


//下一页:
int currentPage1 = 4 ; //定义一个当前页码
int prevpage1 = currentPage1 + 1 <= 5 ?currentPage1 + 1 : 5 ; //求下一页的.(利用三目运算计算)
System.out.println(prevpage1);
    }
}

偏移量计算


1).分页查询的原理就是通过查询语句显示每次查询的记录数量,通过改变条件显示给用户实现分页查询的功能
    
2.) (什么是偏移量:如果要第1000~1010之间的十条数据,查询方式以每页10条显示--->limit 101,10 , 偏移量就是1000,偏移量越大,查询的越慢)
    
3).分页查询中的偏移量的计算方法是:(所要查询页-1)* 每页显示的数量;为什么要减去1呢,因为从数据库查询的数据位置是从0开始算起的,所以就有了这样的公式:$offset = ($nowPage-1)*$num。 //$offset(偏移量) = $nowPage-1(当前页码-1)*(乘)$num(每页显示数量)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值