idea推荐springboot+mybatis+分页查询插件之PageHelper

一.插件使用原因

在进行分页查询操作时,我们总能发现一个问题,就是分页查询这个功能的后端代码,似乎写起来较为繁琐,并且仔细研究可以发现,除了自定义的参数名不同,其他步骤可以说是几乎一致。

所以为了简化开发流程优化代码,因此有这么一款idea插件横空出世。在mybaits框架中,目前最为流行的就是PageHelper分页插件。

通过这一插件,可以大大简化mapper以及serviceimpl层的代码书写。

二.插件与原始写法的区别

一般来说,实现分页查询需要统计总记录数,使用插件可以省略这一步骤。

在进行分页查询时,我们通常通过limit这个关键字来指定分页参数,这个操作也可以通过插件省略。

我们要做的仅有写出查询语句即可。

至于为什么可以这么省略,则是因为我们调用PageHelper中的startPage方法来设置分页参数,然后我们再调用mapper接口中的方法执行正常的查询即可。

三.引入依赖

复制代码
<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>1.4.5</version>
</dependency>

四.修改举例

mapper层:

修改前:

复制代码
@Mapper
public interface Empmapper {
    /**
     * 查询所有员工
     * @return
     */
@Select("select count(*) from emp")
    public long count();
/**
 * 分页询员工
 * @return
 */
@Select("select * from emp limit #{start},#{pageSize}")
public List<Emp> page(@Param("start") Integer start,@Param("pageSize") Integer pageSize);
}

修改后:

复制代码
/*
员工信息查询
 */
@Select("select * from emp")
    public List<Emp> list();

}

serviceimpl层:

修改前:

复制代码
@Service
public class EmpServiceImpl implements EmpService {
    @Autowired
    private Empmapper empmapper;
    @Override
    public PageBean page(Integer page, Integer pageSize) {
//1.获取总记录数
        Long total = empmapper.count();
        //2.获取分页查询结果列表
        Integer start = (page-1)*pageSize;
   List<Emp> rows = empmapper.page(start,pageSize);
        //3.封装PageBean对象并返回
    PageBean pageBean = new PageBean(total,rows);
    return pageBean;
    }

修改后:

复制代码
@Service
public class EmpServiceImpl implements EmpService {
    @Autowired
    private Empmapper empmapper;
@Override
public PageBean page(Integer page, Integer pageSize) {
    //1.设置分页参数
    PageHelper.startPage(page,pageSize);
    //2.执行查询
    List<Emp> rows =empmapper.list();//现在获取到的这个list集合其实是分页查询结果的封装类,还要强转为page类型
    Page<Emp> p = (Page<Emp>) rows;//这是强转,page是插件自带的方法

    //3.封装PageBean对象并返回
    PageBean pageBean = new PageBean(p.getTotal(),p.getResult());
    return pageBean;
}
相关推荐
m0_639817158 小时前
基于springboot个人云盘管理系统【带源码和文档】
java·spring boot·后端
水月wwww9 小时前
Maven项目及Tomcat配置(IDEA)
tomcat·maven·intellij-idea·javaweb
无人不xiao10 小时前
若依 springBoot 配置国际化
spring boot
JosieBook10 小时前
【SpringBoot】32 核心功能 - 单元测试 - JUnit5 单元测试中的嵌套测试与参数化测试详解
spring boot·单元测试·log4j
华仔啊10 小时前
MyBatis-Plus 让你开发效率翻倍!新手也能5分钟上手!
java·后端·mybatis
小坏讲微服务11 小时前
Nginx集群与SpringCloud Gateway集成Nacos的配置指南
spring boot·nginx·spring cloud·gateway
计算机学姐11 小时前
基于SpringBoot的新闻管理系统【协同过滤推荐算法+可视化统计】
java·vue.js·spring boot·后端·spring·mybatis·推荐算法
一 乐12 小时前
远程在线诊疗|在线诊疗|基于java和小程序的在线诊疗系统小程序设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·小程序
serendipity_hky12 小时前
【微服务 - easy视频 | day04】Seata解决分布式事务
java·spring boot·分布式·spring cloud·微服务·架构
大菠萝学姐12 小时前
基于springboot的旅游攻略网站设计与实现
前端·javascript·vue.js·spring boot·后端·spring·旅游