SpringBoot集成MyBatis的分页插件PageHelper实例代码

yizhihongxing

下面就为大家详细讲解“SpringBoot集成MyBatis的分页插件PageHelper实例代码”的完整攻略。

简介

在使用 MyBatis 进行数据库操作时,MySQL主要的限制在于分页查询。但是 Mybatis 配合 PageHelper 便可以轻松解决这个问题。本文将介绍如何在 SpringBoot 中使用 MyBatis 分页插件 PageHelper。

步骤

1. 添加依赖

pom.xml 文件中添加 PageHelper 和 MyBatis 的依赖:

<dependency>
  <groupId>com.github.pagehelper</groupId>
  <artifactId>pagehelper-spring-boot-starter</artifactId>
  <version>1.2.13</version>
</dependency>

<dependency>
  <groupId>org.mybatis.spring.boot</groupId>
  <artifactId>mybatis-spring-boot-starter</artifactId>
  <version>2.0.0</version>
</dependency>

2. 配置 PageHelper

application.yml 文件中添加以下配置:

pagehelper:
  helperDialect: mysql
  reasonable: true
  supportMethodsArguments: true
  params: count=countSql

3. 使用 PageHelper

在 DAO 层的查询方法上添加如下的分页查询配置:

import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;

public interface UserMapper {
  @Select("SELECT * FROM user")
  List<User> findAll();

  @Select("SELECT * FROM user WHERE id=#{id}")
  User findById(@Param("id") Long id);

  @Insert("INSERT INTO user(name, age, email) VALUES(#{name}, #{age}, #{email})")
  int insert(User user);

  @Update("UPDATE user SET name=#{name}, age=#{age}, email=#{email} WHERE id=#{id}")
  int update(User user);

  @Delete("DELETE FROM user WHERE id=#{id}")
  int delete(@Param("id") Long id);

  // 使用 PageHelper 动态分页查询
  @Select("SELECT * FROM user ORDER BY id")
  List<User> findAllByPage();

}

在 service 层中调用 PageHelper 对应的方法实现用户列表的分页查询:

@Service
public class UserServiceImpl implements UserService {

  @Autowired
  private UserMapper userMapper;

  @Override
  public PageInfo<User> findAllByPage(int pageNum, int pageSize) {
    PageHelper.startPage(pageNum, pageSize);
    List<User> userList = userMapper.findAllByPage();
    PageInfo<User> pageInfo = new PageInfo<>(userList);
    return pageInfo;
  }

}

4. 测试

@RunWith(SpringRunner.class)
@SpringBootTest
public class UserServiceTest {

  @Autowired
  private UserService userService;

  @Test
  public void testFindAllByPage() {
    PageInfo<User> pageInfo = userService.findAllByPage(1, 2);
    System.out.println("总记录数:" + pageInfo.getTotal());
    System.out.println("总页数:" + pageInfo.getPages());
    System.out.println("当前页码:" + pageInfo.getPageNum());
    System.out.println("每页记录数:" + pageInfo.getPageSize());
    System.out.println("结果集:" + pageInfo.getList());
  }

}

测试结果:

总记录数:4
总页数:2
当前页码:1
每页记录数:2
结果集:[User(id=1, name=Tom, age=20, email=tom@163.com), User(id=2, name=Jack, age=22, email=jack@163.com)]

另外,还可以使用注解的方式实现分页:

@Select("SELECT * FROM user")
@Options(useGeneratedKeys = true, keyProperty = "id")
List<User> getAllUserByPage(@Param("pageNum") int pageNum, @Param("pageSize") int pageSize);

注解方式和上面介绍的方法是等价的。

总结

本文介绍了在 SpringBoot 中如何集成 MyBatis 分页插件 PageHelper,以及两种不同的使用方式。PageHelper 在实际项目中使用非常方便,可以节省大量的代码量和时间。希望本文能对大家有所帮助。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:SpringBoot集成MyBatis的分页插件PageHelper实例代码 - Python技术站

(0)
上一篇 2023年6月16日
下一篇 2023年6月16日

相关文章

  • java字符串常用操作方法(查找、截取、分割)

    Java字符串常用操作方法攻略 Java字符串是指包含零个或多个字符的对象。字符串常用于存储和操作文本数据,因此,字符串的操作方法在程序开发中非常重要。本文将介绍Java字符串常用操作方法,包括查找、截取和分割。 1. 查找 1.1 indexOf和lastIndexOf方法 indexOf方法返回指定子字符串第一次出现的位置,如果子字符串未找到则返回-1。…

    Java 2023年5月26日
    00
  • Java实现字符串解析为日期时间的方法示例

    引言 在Java中,字符串转日期时间是经常使用的操作之一。本文将讲解利用Java实现字符串解析为日期时间的方法示例。 问题概述 在Java中,我们可以通过SimpleDateFormat类来实现字符串解析为日期时间的目的。SimpleDateFormat是一个日期格式化类,通过指定的日期格式将日期转换为字符串,或将字符串按指定格式解析为日期。可以使用Simp…

    Java 2023年5月20日
    00
  • java JDBC系列教程之JDBC类的简析与JDBC的基础操作

    Java JDBC系列教程之JDBC类的简析与JDBC的基础操作 简介 JDBC(Java Database Connectivity)是Java语言操作关系型数据库的标准应用程序接口,通过JDBC可以实现对多种关系型数据库的连接和操作。 JDBC API是Java SE平台的一部分,它提供了大量的接口和类,以方便Java程序员使用Java语言访问和执行SQ…

    Java 2023年6月16日
    00
  • SpringMVC MVC架构与Servlet使用详解

    SpringMVC MVC架构与Servlet使用详解 什么是MVC架构? MVC(Model View Controller)是一种设计模式,它将一个应用划分为三个部分,即模型(Model)、视图(View)和控制器(Controller),每个部分各自处理自己的任务。MVC设计模式可以使程序的处理逻辑更加清晰,程序的维护和修改更加方便。 在MVC架构中,…

    Java 2023年5月16日
    00
  • Spring Batch 入门示例

    下面详细讲解Spring Batch入门示例的完整攻略,内容包括: Spring Batch 简介 Spring Batch 入门示例概述 示例1:批处理读取 CSV 文件并输出到控制台 示例2:批处理读取数据库中的数据并写入到 XML 文件中 Spring Batch 简介 Spring Batch 是一个高效、强大、可重用的批处理框架,能够处理海量的数据…

    Java 2023年6月3日
    00
  • 详解Java中对象池的介绍与使用

    详解Java中对象池的介绍与使用 对象池是一种常见的对象创建和管理技术,主要用于提高对象创建和销毁的性能和效率。在Java中,使用对象池可以有效地减少垃圾回收和对象创建的开销,提高系统的性能和稳定性。 对象池的概述 对象池是一种对象创建和存储技术,主要用于缓存和复用经常使用的对象,避免重复创建和销毁对象导致的性能开销。相比于直接创建和销毁对象,使用对象池可以…

    Java 2023年5月26日
    00
  • Java内部类原理、概述与用法实例详解

    Java内部类原理、概述与用法实例详解 Java中的内部类是指嵌套在另外一个类内部的类,它们提供了更好的封装和代码组织方式。本文将详细讲解Java内部类的原理、概述和用法实例,并提供两个示例来说明其使用和优势。 内部类原理 Java中的内部类实际上是一种成员类,它与其他成员变量和成员方法一样隶属于其外围类,并可以访问外围类的私有数据和方法,甚至可以访问到其外…

    Java 2023年5月23日
    00
  • java实现简易聊天功能

    Java实现简易聊天功能攻略 1. 确定技术栈 要实现简易聊天功能,需要选择合适的技术栈。Java语言比较适合网络编程,因此可以先选择Java语言作为开发语言。 对于通信协议,可以选择TCP或UDP。TCP是一种可靠传输协议,通过三次握手建立连接,确保数据的可靠性。UDP则是一种不可靠传输协议,不进行连接建立,发送数据时没有确认机制。 对于GUI界面,可以使…

    Java 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部