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(每页显示数量)

猜你喜欢

转载自blog.csdn.net/m0_71202849/article/details/126556326