【SpringBoot】Spring Boot 项目中整合 MyBatis 和 PageHelper

目录

前言

[步骤 1: 添加依赖](#步骤 1: 添加依赖)

[步骤 2: 配置数据源和 MyBatis](#步骤 2: 配置数据源和 MyBatis)

[步骤 3: 配置 PageHelper](#步骤 3: 配置 PageHelper)

[步骤 4: 使用 PageHelper 进行分页查询](#步骤 4: 使用 PageHelper 进行分页查询)

IDEA指定端口启动

总结


前言

Spring Boot 与 MyBatis 的整合是 Java 开发中常见的需求,特别是在使用分页插件如 PageHelper 时。PageHelper 是一个针对 MyBatis 设计的分页插件,可以方便地进行分页查询。下面我将详细说明如何在 Spring Boot 项目中整合 MyBatis 和 PageHelper。

步骤 1: 添加依赖

首先,需要在你的 pom.xml 文件中添加 Spring Boot、MyBatis 和 PageHelper 的依赖。假设你已经有了 Spring Boot 的基础依赖,下面是你需要添加的额外依赖:

XML 复制代码
<!-- Spring Boot MyBatis Starter -->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.4</version>
</dependency>

<!-- MySQL数据库连接 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <scope>runtime</scope>
</dependency>

<!-- PageHelper 分页插件 -->
<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>1.3.0</version>
</dependency>

步骤 2: 配置数据源和 MyBatis

application.propertiesapplication.yml 中配置你的数据库连接和 MyBatis 的相关设置。这里是一个示例配置:

XML 复制代码
# 数据库连接配置
spring.datasource.url=jdbc:mysql://localhost:3306/your_database?serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=your_password
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

# MyBatis 配置
mybatis.type-aliases-package=com.example.demo.model
mybatis.mapper-locations=classpath:mapper/*.xml

步骤 3: 配置 PageHelper

通常,如果使用 pagehelper-spring-boot-starter,你不需要额外配置即可使用 PageHelper,因为这个 Starter 自动配置了 PageHelper。但如果需要自定义参数,可以在 application.properties 中进行配置:

XML 复制代码
# PageHelper 分页插件的配置
pagehelper.helper-dialect=mysql
pagehelper.reasonable=true
pagehelper.support-methods-arguments=true
pagehelper.params=count=countSql

步骤 4: 使用 PageHelper 进行分页查询

在你的 Mapper 接口或者服务中使用 PageHelper 来进行分页。这里是一个基本的使用示例

java 复制代码
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;

@Service
public class UserService {

    @Autowired
    private UserMapper userMapper;

    public PageInfo<User> findUserByPage(int page, int pageSize) {
        // 开启分页
        PageHelper.startPage(page, pageSize);
        // 查询数据
        List<User> users = userMapper.selectAllUsers();
        // 使用PageInfo包装查询结果
        return new PageInfo<>(users);
    }
}

这个服务方法findUserByPage首先通过调用 PageHelper.startPage() 方法启动分页,然后执行查询。PageInfo 对象用于获取分页信息如总页数、总记录数等。

IDEA指定端口启动

在VM options 中:

复制代码
-DServer.port=8080

总结

整合 PageHelper 到 Spring Boot 项目中主要包括添加依赖、配置数据源与 MyBatis、配置 PageHelper 以及在业务逻辑中使用 PageHelper 进行分页查询。这样,你可以在 Spring Boot 应用中方便地进行数据库分页操作,提高应用的性能和用户体验。

相关推荐
武子康7 分钟前
Java-144 深入浅出 MongoDB BSON详解:MongoDB核心存储格式与JSON的区别与应用场景
java·开发语言·数据库·mongodb·性能优化·json·bjson
聪明的笨猪猪8 分钟前
Java Spring “事务” 面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
云飞云共享云桌面31 分钟前
东莞精密机械制造工厂如何10个SolidWorks共用一台服务器资源
java·运维·服务器·网络·数据库·电脑·制造
毕设源码-赖学姐37 分钟前
【开题答辩全过程】以 网络药店管理系统为例,包含答辩的问题和答案
java·eclipse
努力也学不会java38 分钟前
【Java并发】揭秘Lock体系 -- 深入理解ReentrantReadWriteLock
java·开发语言·python·机器学习
埃泽漫笔1 小时前
消息队列延迟与过期问题的实战解决
java·mq
花花无缺1 小时前
资源泄露问题
java·后端·http
爱敲代码的TOM1 小时前
深入剖析Java通信架构下的三种IO模式2
java·开发语言·架构
杨DaB2 小时前
【JavaSE】JVM
java·jvm
lang201509282 小时前
掌握MyBatis Java API:高效操作数据库
java·数据库·mybatis