基本逻辑算法
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(每页显示数量)