MyBatis使⽤PageHelper(MySQL)

MyBatis使⽤PageHelper(MySQL)



一、 limit分⻚

  • mysql的limit后⾯两个数字:
    • 第⼀个数字:startIndex(起始下标。下标从0开始。)
    • 第⼆个数字:pageSize(每⻚显示的记录条数)
  • 假设已知⻚码pageNum,还有每⻚显示的记录条数pageSize,startIndex = (pageNum - 1) * pageSize
  • 所以,标准通⽤的mysql分⻚SQL:
xml 复制代码
select * from
 tableName ......
limit (pageNum - 1) * pageSize, pageSize
  • 在实际的开发中,一般由前端或者后端人员将 pageNum、pageSize 计算好后传递给 mybatis。
xml 复制代码
<select id="selectActivityByConditionForPage" parameterType="map" resultMap="BaseResultMap">
  select
      a.id,u1.name as owner,a.name,a.start_date,a.end_date,a.cost,a.description,a.create_time,u2.name as create_by,a.edit_time,u3.name as edit_by
  from
      tbl_activity a
  join
      tbl_user u1 on a.owner=u1.id
  join
      tbl_user u2 on a.create_by=u2.id
  left join
      tbl_user u3 on a.edit_by=u3.id
  <where>
    <if test="name!=null and name!=''">
      and a.name like '%' #{name} '%'
    </if>
    <if test="owner!=null and owner!=''">
      and u1.name like '%' #{owner} '%'
    </if>
    <if test="startDate!=null and startDate!=''">
      and a.start_date&gt;=#{startDate}
    </if>
    <if test="endDate!=null and endDate!=''">
      and a.end_date&lt;=#{endDate}
    </if>
  </where>
  order by a.create_time desc
  limit #{beginNo},#{pageSize}
</select>

二、PageHelper插件

第⼀步:引⼊依赖

xml 复制代码
<dependency>
	<groupId>com.github.pagehelper</groupId>
	<artifactId>pagehelper</artifactId>
	<version>5.3.2</version>
</dependency>

第⼆步:在mybatis-config.xml⽂件中配置插件

  • typeAliases标签下⾯进⾏配置:

    xml 复制代码
    <plugins>
    	<plugin interceptor="com.github.pagehelper.PageInterceptor"/>
    </plugins>

第三步:编写Java代码

  • 关键点:

    • 在查询语句之前开启分⻚功能。(只有紧跟在 PageHelper.startPage 方法后的第一个 Mybatis 的查询(Select)方法会被分页。)
    • 在查询语句之后封装PageInfo对象。(PageInfo对象将来会存储到 request 域当中。在⻚⾯上展示。)
    java 复制代码
    @Test
    public void testPageHelper() throws Exception{
    	SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(Resources.getResourceAsStream("mybatis-config.xml"));
    	SqlSession sqlSession = sqlSessionFactory.openSession();
    	CarMapper mapper = sqlSession.getMapper(CarMapper.class);
    	// 开启分⻚
    	PageHelper.startPage(2, 2);
    	// 执⾏查询语句
    	List<Car> cars = mapper.selectAll();
    	// 获取分⻚信息对象
    	PageInfo<Car> pageInfo = new PageInfo<>(cars, 5);
    	System.out.println(pageInfo);
    }

第四步:格式化结果查看

  • 对于其中的属性都有对应的方法来获取,需要的时候查找即可。
  • 每个属性的含义可以在使用的时候上网查找。
json 复制代码
PageInfo{
	pageNum=2, pageSize=2, size=2, startRow=3, endRow=4, total=6, pages=3,list=Page{count=true, pageNum=2, pageSize=2, startRow=2, endRow=4, total=6, pages=3, reasonable=false, pageSizeZero=false}
	[Car{id=86, carNum='1234', brand='丰⽥霸道', guidePrice=50.5, produceTime='2020-1011', carType='燃油⻋'},
	Car{id=87, carNum='1234', brand='丰⽥霸道', guidePrice=50.5, produceTime='2020-10-11', carType='燃油⻋'}],
	prePage=1, nextPage=3, isFirstPage=false, isLastPage=false, hasPreviousPage=true, hasNextPage=true,navigatePages=5, navigateFirstPage=1, navigateLastPage=3,navigatepageNums=[1, 2, 3]
}

三、SpringBoot3 集成 PageHelper 插件

  • Add the following dependency to your pom.xml:
xml 复制代码
<dependency>
  <groupId>com.github.pagehelper</groupId>
  <artifactId>pagehelper-spring-boot-starter</artifactId>
  <version>2.1.0</version>
</dependency>

相关推荐
M1A19 分钟前
Java 面试系列第一弹:基础问题大盘点
java·后端·mysql
He.ZaoCha9 分钟前
函数-1-字符串函数
数据库·sql·mysql
二当家的素材网17 分钟前
Centos和麒麟系统如何每天晚上2点10分定时备份达梦数据库
linux·数据库·centos
白仑色24 分钟前
Oracle 存储过程、函数与触发器
数据库·oracle·数据库开发·存储过程·plsql编程
叁沐1 小时前
MySQL 09 普通索引和唯一索引,应该怎么选择?
mysql
头发那是一根不剩了2 小时前
Spring Boot 多数据源切换:AbstractRoutingDataSource
数据库·spring boot·后端
草履虫建模2 小时前
Redis:高性能内存数据库与缓存利器
java·数据库·spring boot·redis·分布式·mysql·缓存
苹果醋32 小时前
Vue3组合式API应用:状态共享与逻辑复用最佳实践
java·运维·spring boot·mysql·nginx
一个处女座的测试2 小时前
Python语言+pytest框架+allure报告+log日志+yaml文件+mysql断言实现接口自动化框架
python·mysql·pytest
泊浮目3 小时前
未来数据库硬件-计算篇
数据库·云计算·操作系统