Springboot Mybatis使用pageHelper实现分页查询

以下介绍实战中数据库框架使用的是mybatis,对整合mybatis此处不做介绍。

使用pageHelper实现分页查询其实非常简单,共两步:

一、导入依赖;   

二、添加配置;   

 

 

那么开始,

第一步:

pom.xml添加依赖:

<!--分页插件 pagehelper -->
<dependency>
   <groupId>com.github.pagehelper</groupId>
   <artifactId>pagehelper-spring-boot-starter</artifactId>
   <!-- 特别注意版本问题 -->
   <version>1.2.3</version>
</dependency>

 第二步:

aplication.yml添加配置:

#分页pageHelper
pagehelper:
  helper-dialect: mysql
  reasonable: true
  support-methods-arguments: true

 ·helper-dialect:

配置使用哪种数据库语言,不配置的话pageHelper也会自动检测

·reasonable:

配置分页参数合理化功能,默认是false。 #启用合理化时,如果pageNum<1会查询第一页,如果pageNum>总页数会查询最后一页; #禁用合理化时,如果pageNum<1或pageNum>总页数会返回空数据。

·params:

为了支持startPage(Object params)方法,增加了该参数来配置参数映射,用于从对象中根据属性名取值; 可以配置 pageNum,pageSize,count,pageSizeZero,reasonable,不配置映射的用默认值, 默认值为pageNum=pageNum;pageSize=pageSize;count=countSql;reasonable=reasonable;pageSizeZero=pageSizeZero。

·support-methods-arguments:

支持通过Mapper接口参数来传递分页参数,默认值false,分页插件会从查询方法的参数值中,自动根据上面 params 配置的字段中取值,查找到合适的值时就会自动分页。

第三步,

先将需要查询的数据库表建起来,简单填充数据:

然后mapper层写上查询该表数据返回List的方法:

//查询所有
List<User> queryUserInfo();

在service以及impl也写上相关方法:

//查询所有
List<User> queryUserInfo();
@Override
public List<User> queryUserInfo() {

    return userMapper.queryUserInfo();
}

相关的mapper.xml就不做过多介绍了,就是一个查询。

 

ok,接下来开始使用分页插件,配合上面的查询实现分页查询:

在userService上添加 分页查询方法2个:

List<User> findAllUserByPageF(int pageNum,int pageSize);

PageInfo<User> findAllUserByPageS(int pageNum, int pageSize);

userServiceImpl上添加 分页查询实现:

@Override
public List<User> findAllUserByPageF(int pageNum, int pageSize) {
    // TODO Auto-generated method stub
    PageHelper.startPage(pageNum, pageSize);
    List<User> lists = userMapper.queryUserInfo();
    return lists;
}

@Override
public PageInfo<User> findAllUserByPageS(int pageNum, int pageSize) {
    // TODO Auto-generated method stub
    PageHelper.startPage(pageNum, pageSize);
    List<User> lists = userMapper.queryUserInfo();
    PageInfo<User> pageInfo = new PageInfo<User>(lists);
    return pageInfo;

}

最后在controller写上测试接口,

@GetMapping("/testPageHelper1")
public PageInfo<User> testPageHelper1(){
    PageInfo<User> queryResult = userService.findAllUserByPageS(1, 5);
    return queryResult;
}

@GetMapping("/testPageHelper2")
public List<User> testPageHelper2(){
    List<User> queryResult = userService.findAllUserByPageF(1, 5);
    return queryResult;
}

 

然后用POSTMAN 分别调接口看看结果:

 

 

最后附上分别调用10次的性能分析简图(来自DRUID):

OK,简单实战介绍到此吧。

 

 

PageInfo的参数解释,可以看看我这篇:

https://blog.csdn.net/qq_35387940/article/details/105067813 

  • 96
    点赞
  • 551
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 15
    评论
Spring Boot整合MyBatis PageHelper可以实现分页查询功能。下面是一个简单的示例: 首先,需要在pom.xml文件中添加MyBatis PageHelper的依赖: ```xml <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper-spring-boot-starter</artifactId> <version>1.2.13</version> </dependency> ``` 然后,在application.properties或application.yml文件中配置数据源相关信息,例如: ```yaml spring.datasource.url=jdbc:mysql://localhost:3306/test spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.jdbc.Driver ``` 接下来,在Spring Boot的启动类上添加`@MapperScan`注解,指定要扫描的Mapper接口所在的包路径,例如: ```java @SpringBootApplication @MapperScan("com.example.mapper") public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 然后,在Mapper接口中定义查询方法,使用PageHelper提供的静态方法`startPage`来启动分页功能,例如: ```java import com.github.pagehelper.Page; import com.github.pagehelper.PageHelper; @Mapper public interface UserMapper { List<User> getUsers(); @Select("SELECT * FROM users") @ResultMap("userResultMap") Page<User> getUsersWithPage(); } ``` 最后,在Service或Controller层调用Mapper接口的方法即可实现分页查询,例如: ```java @Service public class UserService { @Autowired private UserMapper userMapper; public List<User> getUsers() { return userMapper.getUsers(); } public Page<User> getUsersWithPage(int pageNum, int pageSize) { PageHelper.startPage(pageNum, pageSize); return userMapper.getUsersWithPage(); } } ``` 这样就完成了Spring Boot与MyBatis PageHelper的整合,可以通过调用`getUsersWithPage`方法实现分页查询操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小目标青年

对你有帮助的话,谢谢你的打赏。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值