MyBatis-Plus分页接口实现教程:Spring Boot中如何编写分页查询

🌟 前言

欢迎来到我的技术小宇宙!🌌 这里不仅是我记录技术点滴的后花园,也是我分享学习心得和项目经验的乐园。📚 无论你是技术小白还是资深大牛,这里总有一些内容能触动你的好奇心。🔍

  • 🤖 洛可可白:个人主页

  • 🔥 个人专栏:✅前端技术 ✅后端技术

  • 🏠 个人博客:洛可可白博客

  • 🐱 代码获取:bestwishes0203

  • 📷 封面壁纸:洛可可白wallpaper

在这里插入图片描述

文章目录

  • MyBatis-Plus分页接口实现教程:Spring Boot中如何编写分页查询
    • MyBatis-Plus 简介
    • Spring Boot 简介
    • 实现步骤
      • 1. 添加 MyBatis-Plus 依赖
      • 2. 配置分页插件
      • 3. 创建服务层接口
      • 4. 创建控制器
      • 5. 运行应用并测试
      • 6.全部代码
    • 结语
    • 🎉 往期精彩回顾

MyBatis-Plus分页接口实现教程:Spring Boot中如何编写分页查询

MyBatis-Plus 是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。它提供了强大的分页插件,可以轻松实现分页查询的功能。在 Spring Boot 项目中使用 MyBatis-Plus 可以大大简化分页逻辑的编写。本文将介绍如何在 Spring Boot 项目中使用 MyBatis-Plus 实现分页接口。

MyBatis-Plus 简介

MyBatis-Plus(简称 MP)是 MyBatis 的一个增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。它提供了代码生成器、分页插件、性能分析插件、全局通用操作、MetaObject 等一系列功能,使得 MyBatis 变得更加易用。

Spring Boot 简介

Spring Boot 是 Spring 的一个模块,用于简化新 Spring 应用的初始搭建以及开发过程。Spring Boot 旨在简化配置,通过约定大于配置的原则,提供了大量的默认配置,使得开发者能够快速启动和部署 Spring 应用。

实现步骤

1. 添加 MyBatis-Plus 依赖

pom.xml 文件中添加 MyBatis-Plus 的依赖:

        <!--mybatis-plus--><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.3.1</version></dependency>

在这里插入图片描述

Springboot只能使用3.1.5及以下版本!!!

2. 配置分页插件

在 Spring Boot 的配置类中添加分页插件的配置:

import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
//@MapperScan("com.example.demo.mapper")
public class MybatisPlusConfig {/*** 新增分页拦截器,并设置数据库类型为mysql** @return*/@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;}
}

3. 创建服务层接口

创建一个服务层接口,用于定义分页查询的方法:

@Service
public class UserServiceImpl implements UserService {@Autowiredprivate UserMapper userMapper;@Overridepublic Result listPageUser(@RequestParam Integer page, @RequestParam Integer pageSize) {//分页参数Page<UserEntity> rowPage = new Page<>(page, pageSize);//queryWrapper组装查询where条件LambdaQueryWrapper<UserEntity> queryWrapper = new LambdaQueryWrapper<>();rowPage = userMapper.selectPage(rowPage, queryWrapper);return Result.success("数据列表", rowPage);}
}

4. 创建控制器

创建一个控制器,用于处理 HTTP 请求并调用服务层的分页查询方法:

@RestController
@RequestMapping("/user")
public class UserController {@Autowiredprivate UserServiceImpl userServiceImpl;@PostMapping("/listPage")@Operation(summary = "列表分页")public Result listPageUser(@RequestParam Integer page, @RequestParam Integer pageSize) {return userServiceImpl.listPageUser(page, pageSize);}
}

5. 运行应用并测试

启动 Spring Boot 应用,并通过 Postman 或其他 API 测试工具发送 POST 请求到 /user/listPage 端点,传递 pagepageSize 参数,即可测试分页查询功能。

6.全部代码

import com.alibaba.excel.EasyExcel;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.example.common.req.IdParam;
import com.example.common.resp.Result;
import com.example.system.entity.UserEntity;
import com.example.system.mapper.UserMapper;
import com.example.system.resp.LoginResp;
import com.example.system.service.UserService;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.servlet.http.HttpSession;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;import java.io.IOException;
import java.io.InputStream;
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;
import java.text.SimpleDateFormat;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Date;
import java.util.List;
import java.util.Locale;
import java.util.Objects;/*** <p>* 用户表 前端控制器* </p>** @author he* @since 2024-03-23*/
@Tag(name = "用户")
@RestController
@RequestMapping("/userEntity")
public class UserController {@Autowiredprivate UserMapper userMapper;@Autowiredprivate UserService userService;private final String id = "User_id";SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");@Operation(summary = "列表")@PostMapping("/list")public Result listUser() {return Result.success("数据列表", userService.list());}@Operation(summary = "存在")@PostMapping("/exist")public Result existUser(@RequestBody @Validated IdParam param) {QueryWrapper<UserEntity> wrapper = new QueryWrapper<>();wrapper.eq(id.toLowerCase(Locale.ROOT), param.getId());long count = userService.count(wrapper);if (count == 0) return Result.success("ID不存在", false);return Result.success("ID已存在", true);}@Operation(summary = "保存")@PostMapping("/insert")public Result insertUser(@RequestBody @Validated UserEntity param) {QueryWrapper<UserEntity> wrapper = new QueryWrapper<>();wrapper.eq(id.toLowerCase(Locale.ROOT), param.getId());if (userService.count(wrapper) != 0) return Result.failure("ID已存在", sdf.format(new Date()));if (userService.save(param)) return Result.success("保存成功", sdf.format(new Date()));return Result.failure("保存失败", sdf.format(new Date()));}@Operation(summary = "删除")@PostMapping("/delete")public Result deleteUser(@RequestBody @Validated IdParam param) {QueryWrapper<UserEntity> wrapper = new QueryWrapper<>();wrapper.eq(id.toLowerCase(Locale.ROOT), param.getId());if (userService.count(wrapper) == 0) return Result.failure("ID不存在", param.getId());if (userService.remove(wrapper)) return Result.success("删除成功", param.getId());return Result.failure("删除失败", param.getId());}@Operation(summary = "修改")@PostMapping("/update")public Result updateUser(@RequestBody @Validated UserEntity param) {QueryWrapper<UserEntity> wrapper = new QueryWrapper<>();wrapper.eq(id.toLowerCase(Locale.ROOT), param.getId());if (userService.count(wrapper) == 0) return Result.failure("ID不存在", sdf.format(new Date()));if (userService.updateById(param)) return Result.success("修改成功", sdf.format(new Date()));return Result.failure("修改失败", sdf.format(new Date()));}@Operation(summary = "查询")@PostMapping("/select")public Result selectUser(@RequestBody @Validated IdParam param) {QueryWrapper<UserEntity> wrapper = new QueryWrapper<>();wrapper.eq(id.toLowerCase(Locale.ROOT), param.getId());if (userService.count(wrapper) == 0) return Result.failure("ID不存在", param.getId());return Result.success(userService.getOne(wrapper));}@Operation(summary = "查询byAcc")@PostMapping("/selectByAcc/{param}")public Result selectUserByAcc(@PathVariable @Validated String param) {QueryWrapper<UserEntity> wrapper = new QueryWrapper<>();String acc = "User_acc";wrapper.eq(acc.toLowerCase(Locale.ROOT), param);if (userService.count(wrapper) == 0) return Result.failure("账号不存在", sdf.format(new Date()));return Result.success(userService.getOne(wrapper));}@Operation(summary = "列表分页")@PostMapping("/listPage")public Result listPageUser(@RequestParam Integer page, @RequestParam Integer pageSize) {//分页参数Page<UserEntity> rowPage = new Page(page, pageSize);//queryWrapper组装查询where条件LambdaQueryWrapper<UserEntity> queryWrapper = new LambdaQueryWrapper<>();rowPage = userMapper.selectPage(rowPage, queryWrapper);return Result.success("数据列表", rowPage);}@Operation(summary = "导出数据")@PostMapping("exportExcel")public void exportExcelUser(HttpServletResponse response) throws IOException {response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setCharacterEncoding("utf-8");String fileName = URLEncoder.encode("轮播图", StandardCharsets.UTF_8).replaceAll("\\+", "%20");List<UserEntity> list = userService.list();response.setHeader("Content-disposition", "attachment;filename*=" + fileName + ".xlsx");EasyExcel.write(response.getOutputStream(), UserEntity.class).sheet("轮播图").doWrite(list);}@Operation(summary = "导入数据")@PostMapping("/importExcel")public Result importExcelUser(MultipartFile file) {try {//获取文件的输入流InputStream inputStream = file.getInputStream();List<UserEntity> list = EasyExcel.read(inputStream) //调用read方法//注册自定义监听器,字段校验可以在监听器内实现//.registerReadListener(new UserListener()).head(UserEntity.class) //对应导入的实体类.sheet(0) //导入数据的sheet页编号,0代表第一个sheet页,如果不填,则会导入所有sheet页的数据.headRowNumber(1) //列表头行数,1代表列表头有1行,第二行开始为数据行.doReadSync();//开始读Excel,返回一个List<T>集合,继续后续入库操作//模拟导入数据库操作for (UserEntity entity : list) {userService.saveOrUpdate(entity);}return Result.success("导入成功", sdf.format(new Date()));} catch (IOException exception) {throw new RuntimeException(exception);}}}

结语

通过上述步骤,我们在 Spring Boot 项目中使用 MyBatis-Plus 实现了一个分页查询接口。MyBatis-Plus 提供的分页插件极大地简化了分页逻辑的编写,使得开发者能够更专注于业务逻辑的实现。通过学习和实践,你可以更深入地理解 MyBatis-Plus 和 Spring Boot 的强大功能,以及如何将它们应用到实际的开发工作中。

如果对你有帮助,点赞👍、收藏💖、关注🔔是我更新的动力!👋🌟🚀

🎉 往期精彩回顾

Element-Plus下拉菜单边框去除教程

  • 591阅读 · 15点赞 · 23收藏

Web实现猜数字游戏:JavaScript DOM基础与实例教程

  • 556阅读 · 11点赞 · 9收藏

Web实现名言生成器:JavaScript DOM基础与实例教程

  • 625阅读 · 19点赞 · 16收藏

Web实现井字棋游戏:JavaScript DOM基础与实例教程

  • 598阅读 · 27点赞 · 16收藏

Web实现表格单选全选与反选操作:JavaScript DOM基础与实例教程

  • 858阅读 · 16点赞 · 9收藏

H5实现Web ECharts教程:轻松创建动态数据图表

  • 1134阅读 · 21点赞 · 8收藏

浏览器DOM操作基础:禁用右键菜单与阻止文字选中

  • 1018阅读 · 33点赞 · 24收藏

缤纷浏览器 —— 一键换肤,个性随心换(H5实现浏览器换肤效果)

  • 597阅读 · 11点赞 · 6收藏

广州5k前端面试题惊呆我!!!(内容太肝,谨慎入内)

  • 826阅读 · 29点赞 · 24收藏

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/772838.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity VisionOS开发流程

Unity开发环境 Unity Pro, Unity Enterprise and Unity Industry 国际版 Mac Unity Editor(Apple silicon) visionOS Build Support (experimental) 实验版 Unity 2022.3.11f1 NOTE: 国际版与国服版Pro账通用&#xff0c;需要激活Pro的许可证。官方模板v0.6.2,非Pro版本会打…

稀碎从零算法笔记Day29-LeetCode:单词拆分

死磕dp的第二天了 题型&#xff1a;dp&#xff0c;字符串&#xff0c;二维数组&#xff0c;背包类 链接&#xff1a;139. 单词拆分 - 力扣&#xff08;LeetCode&#xff09; 来源&#xff1a;LeetCode 题目描述 给你一个字符串 s 和一个字符串列表 wordDict 作为字典。如果…

【探究图论中dfs记忆化,搜索,递推,回溯关系】跳棋,奶牛隔间, 小A和uim之大逃离 II

本篇很高能&#xff0c;如有错误欢迎指出&#xff0c;本人能力有限&#xff08;需要前置知识记忆化dfs&#xff0c;树形dp&#xff0c;bfsdp&#xff0c;tarjan&#xff09; 另外&#xff0c;本篇之所以属于图论&#xff0c;也是想让各位明白&#xff0c;dfs就是就是在跑图&am…

mysql80-DBA数据库学习2

权限管理 创建用户 create user user1localhost identified by QianFeng123; select * from mysql.user; 或者select * from mysql.user\G进行分行显示 密码要求&#xff1a; 1组成&#xff1a; 由小写字母、大写字母、数字、字符 中的三项组成 &#xff0c;也就是3/4 2长度…

单片机---独立按键

[3-1] 独立按键控制LED亮灭_哔哩哔哩_bilibili 按下的时候连接&#xff0c;松开的时候断开。 一头接GND&#xff08;电源负极&#xff09;&#xff0c;另一头接I/O口。 单片机上电时&#xff0c;所有I/O口为高电平。 按键没有按下&#xff0c;I/O口为高电平。 按键按下&…

标题:深入了解 ES6 模块化技术

在 ES6 版本之前&#xff0c;JavaScript 一直缺乏一个内置的模块系统&#xff0c;这给大型项目的开发带来了一些挑战。ES6 引入了模块化的概念&#xff0c;为 JavaScript 开发者提供了一种更好的组织和管理代码的方式。 模块是 JavaScript 的一种代码组织方式&#xff0c;它将代…

界面控件DevExpress WinForms/WPF v23.2 - 电子表格支持表单控件

DevExpress WinForm拥有180组件和UI库&#xff0c;能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForm能完美构建流畅、美观且易于使用的应用程序&#xff0c;无论是Office风格的界面&#xff0c;还是分析处理大批量的业务数据&#xff0c;它都能轻松胜任…

QGraphicsView(平移/缩放/旋转)

简述 Graphics View提供了一个平台&#xff0c;用于大量自定义 2D 图元的管理与交互&#xff0c;框架包括一个事件传播架构&#xff0c;支持场景 Scene 中的图元 Item 进行精确的双精度交互功能。Item 可以处理键盘事件、鼠标按下、移动、释放和双击事件&#xff0c;同时也能跟…

鸿蒙OS封装【axios 网络请求】(类似Android的Okhttp3)

Okhttp.ets /*** 网络请求*/ import axios from ohos/axios import httpConstants from ../net/HttpConstants import errorCode from ../utils/errorCode import toast from ../utils/ToastUtils import router from ../utils/RouterUtils import SPUtils from ../utils/SPUt…

毕马威:量子计算成未来3-5年重大挑战

毕马威&#xff08;KPMG&#xff09;是一家全球性的专业服务网络&#xff0c;其历史可追溯到19世纪末。作为“四大”会计师事务所之一&#xff0c;毕马威在审计、税务和咨询服务领域享有盛誉。公司在全球范围内拥有多个办事处&#xff0c;服务遍及各个行业&#xff0c;包括金融…

5.1 物联网RK3399项目开发实录-Android开发之ADB使用(wulianjishu666)

物联网项目开发实例&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/11VQMhHfIL9mZhNlls4wmjw?pwd0gfa 1. ADB 使用 1.1. 前言 ADB&#xff0c;全称 Android Debug Bridge&#xff0c;是 Android 的命令行调试工具&#xff0c;可以完成多种功能&#xff0c;如跟踪系…

CentOS Stream 8系统配置阿里云YUM源

Linux运维工具-ywtool 目录 一.系统环境二.修改yum文件2.1 CentOS-Stream-AppStream.repo2.2 CentOS-Stream-BaseOS.repo2.3 CentOS-Stream-Extras.repo 三.只有一个配置文件四.其他知识4.1 如果想要启用其他源,修改文件配置:enabled14.2 国内源链接 一.系统环境 CentOS Strea…

Linux一键式安装JDK、Mysql、Redis、Nginx(附带安装包,无需手动配置密码等)

安装包 新服务器安装前置准备 1. 设置系统时区 # 查看服务器时区 timedatectl # 设置服务器时区为上海 timedatectl set-timezone Asia/Shanghai # 设置系统时间为“2021-3-19 11:00:00” date -s "2021-3-19 11:00:00" # 查看校准后的系统时间 date …

[C++]内联函数(内联函数的概念,内联函数的特性,内联函数与宏的区别)

一、内联函数的概念 以inline修饰的的函数叫内联函数&#xff0c;编译时C编译器会在调用内联函数的位置将内联函数展开&#xff0c;内联函数没有调用函数参数压栈的开销&#xff0c;内联函数可以提高程序的运行效率。 例子&#xff1a; 没有使用内联函数 使用内联函数&#xff…

【SpringBoot整合系列】SpringBoot3.x整合Swagger

目录 产生背景官方解释&#xff1a;作用SpringBoot3整合Swagger注意事项swagger3 常用注解SpringBoot3.x整合Swagger1.创建工程(jdk:17,boot:3.2.4)2.引入pom依赖3.application.yml添加配置4.添加swagger3.0配置5.控制器层(Controller)6.模型层(Model)7.启动并测试【Get请求接口…

一、Spring Cloud(Base工程构建)

一、Spring Cloud&#xff08;Base工程构建&#xff09; 1.1 Spring Cloud 简述 1.1.1 Spring Cloud 版本推荐 在讲解 Spring Cloud 之前&#xff0c;首先推荐一下各个依赖的版本&#xff0c;以免出现版本错误 版本推荐 必须根据以上版本&#xff0c;否则可能会出现一些不…

Hana数据库 No columns were bound prior to calling SQLFetch or SQLFetchScroll

在php调用hana数据库的一个sql时报错了&#xff0c;查表结构的sql&#xff1a; select * from sys.table_columns where table_name VBAP SQLSTATE[SL009]: <<Unknown error>>: 0 [unixODBC][Driver Manager]No columns were bound prior to calling SQLFetch …

基于SpringBoot和Leaflet的行政区划地图掩膜效果实战

目录 前言 一、掩膜小知识 1、GIS掩膜的实现原理 2、图层掩膜流程 二、使用插件 1、leaflet-mask介绍 2、核心代码解释 三、完整实例实现 1、后台逻辑实现 2、省级行政区划查询实现 3、行政区划定位及掩膜实现 4、成果展示 总结 前言 在之前的博客提过按空间矢量…

【STM32+HAL】I2C+DMA读取AS5600编码器

一、DMA的应用 有关更多DMA的应用&#xff0c;详见【STM32HAL】DMA应用 二、HAL库配置 1、开启I2C 开启对应DMA及中断 2、开启串口通信 至此&#xff0c;HAL库配置完毕 三、DMA版&#xff08;高效但不稳定&#xff09; 1、as5600.c #include "AS5600.h" #includ…

数据结构与算法 顺序表的基本运算

一、实验内容 编写一个程序实现&#xff0c;实现顺序表的各种基本运算&#xff08;假设顺序表的元素类型为char&#xff09;&#xff0c;并以此为基础设计一个程序完成下列功能&#xff1a; &#xff08;1&#xff09;初始化顺序表&#xff1b; &#xff08;2&#xff09;采…