MyBatis学习笔记(十三) —— 分页插件
创始人
2024-05-31 21:25:16
0

13、分页插件

SQL语句中添加

limit index,pageSize

pageSize: 每页显示的条数

pageNum: 当前页的页码

index: 当前页的起始索引, index = (pageNum + 1) * pageSize

count: 总记录数

totalPage: 总页数

totalPage=count/pageSize;

if(count % pageSize !=0 ){

totalPage += 1;

}

pageSize=4, pageNum=1, index=0 limit 0,4

pageSize=4, pageNum=3, index=8 limit 8,4

pageSize=4, pageNum=6, index=20 limit 8,4

13.1、分页插件的使用步骤

13.1.1、添加依赖

pom.xml中添加pagehelper分页插件所需的依赖

com.github.pagehelperpagehelper5.2.0

13.1.2、配置分页插件

在MyBatis的核心配置文件中配置插件



img

测试

@Test
public void testPage(){SqlSession sqlSession = SqlSessionUtils.getSqlSession();EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);//查询功能之前开启分页功能PageHelper.startPage(1,4);//pageNum:1 当前页是第1页,每页4条List list = mapper.selectByExample(null);list.forEach(System.out::println);
}

img

默认访问第一页,每页4条。sql语句中是 limit 0,4,可简写为limit 4

img

13.2、分页插件的使用

① 在查询功能之前使用 PageHelper.startPage(int pageNum, int pageSize)开启分页功能

pageNum: 当前页的页码

pageSize: 每页显示的条数

② 在查询获取list集合之后,使用PageInfo pageInfo = new PageInfo<>(List list,int navigatePages) 获取分页相关数据

list: 分页之后的数据

navigatePages: 导航分页的页码数

③ 分页相关数据

PageInfo{

pageNum=8, pageSize=4, size=2, startRow=29, endRow=30, total=30, pages=8,

list=Page{count=true, pageNum=8, pageSize=4, startRow=28, endRow=32, total=30,

pages=8, reasonable=false, pageSizeZero=false},

prePage=7, nextPage=0, isFirstPage=false, isLastPage=true, hasPreviousPage=true,

hasNextPage=false, navigatePages=5, navigateFirstPage4, navigateLastPage8,

navigatepageNums=[4, 5, 6, 7, 8]

}

pageNum: 当前页的页码

pageSize: 每页显示的条数

size: 当前页显示的真实条数

total: 总记录数

pages: 总页数

prePage: 上一页的页码

nextPage: 下一页的页码

isFirstPage/isLastPage: 是否为第一页/最后一页

hasPreviousPage/hasNextPage: 是否存在上一页/下一页

navigatePages: 导航分页的页码数

navigatepageNums: 导航分页的页码,[1,2,3,4,5]

测试代码:

package com.fan.mybatis.test;import com.fan.mybatis.mapper.EmpMapper;
import com.fan.mybatis.pojo.Emp;
import com.fan.mybatis.utils.SqlSessionUtils;
import com.github.pagehelper.Page;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;import java.util.List;/**
* @Date: 2023/03/10
* @Author: fan
* @Description:
*/
public class PageTest {@Testpublic void testPage(){SqlSession sqlSession = SqlSessionUtils.getSqlSession();EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);//查询功能之前开启分页功能Page page = PageHelper.startPage(1, 4);//pageNum:1 当前页是第1页,每页4条List list = mapper.selectByExample(null);list.forEach(System.out::println);//查询功能之后可以获取分页相关的所有数据PageInfo pageInfo = new PageInfo<>(list,5);list.forEach(System.out::println);System.out.println(pageInfo);}
}
 

img

相关内容

热门资讯

摸摸你的腰mp3 摸摸你的腰mp3摸摸你的腰mp3... 摸摸你的腰mp3 展开 好多水我摸摸你的头好温柔,我...
最近书荒啊,谁有没有好看的言情... 最近书荒啊,谁有没有好看的言情小说介绍一些啊!不配【有三部】,赶夫上轿【轻松】,南风过境【宠文】,花...
金饰克价再次涨至1000元!黄... 本文来自微信公众号“大象新闻”6月30日,现货黄金盘中一度跌至一个月内新低,随后开始大幅反弹,收报3...
西安警方回应“中华田园犬禁养”... 6月30日,网传陕西省西安市公安局限制养犬管理办公室发布的“重点限养区禁止饲养烈性犬和大型犬”图片引...
小学生常常以教师的行为为榜样,... 小学生常常以教师的行为为榜样,教师也处处表现出对表现好的学生的喜爱和认可,学生从中获得派生地位。这种...
香港维持对日本水产进口管制 作者 | 《财经》特派香港记者 焦建 编辑 | 苏琦  日本水产及日式料理多年来受港人追捧,日本水产...
成都先导终止收购海纳医药65%... 6月30日,成都先导药物开发股份有限公司(以下简称“成都先导”)宣布,因未能就交易事项的核心条款达成...
11岁女孩身高137cm,警惕...   炒股就看金麒麟分析师研报,权威,专业,及时,全面,助您挖掘潜力主题机会! 转自:医学界*仅供医...
《勇气》阅读题理解 《勇气》阅读题理解 19世纪,在英国的名门公立学校—哈罗学校常常会出现以强凌弱、以大欺小的事情。...
建设银行再创历史新高!牵手“山...   炒股就看金麒麟分析师研报,权威,专业,及时,全面,助您挖掘潜力主题机会!   中国基金报记者 ...