MyBatisPlus--分页插件

devtools/2025/1/20 16:40:59/

文章目录

  • MyBatisPlus自带分页插件
    • 添加配置类或在启动类中配置分页插件
    • 测试
  • 自定义分页
    • 在UserMapper中定义接口方法
    • UserMapper.xml中编写SQL
    • 测试


MyBatisPlus自带分页插件

MyBatis Plus自带分页插件,只要简单的配置即可实现分页功能

添加配置类或在启动类中配置分页插件

创建配置类方式:

java">package com.qcby.mybatisPlus.config;import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class MybatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor(){MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();//添加分页插件interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;}
}

启动类中配置分页插件方式(推荐):

java">@SpringBootApplication
@MapperScan("com.qcby.mybatisPlus.mapper")
public class MybatisPlusdemo01 {public static void main(String[] args) {SpringApplication.run(MybatisPlusdemo01.class, args);}@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor(){MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();//添加分页插件interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;}
}

测试

java">package com.qcby.mybatisPlus;import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.qcby.mybatisPlus.mapper.UserMapper;
import com.qcby.mybatisPlus.model.User;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;import java.util.List;@SpringBootTest
public class MybatisPlusPageTest {@Autowiredprivate UserMapper userMapper;@Testpublic void testPage() {//设置分页参数Page<User> page = new Page<>(1, 5);userMapper.selectPage(page,null);//获取分页数据List<User> list = page.getRecords();list.forEach(System.out::println);System.out.println("MyBatisPlus自带分页插件");System.out.println("当前页:"+page.getCurrent());System.out.println("每页显示的条数:"+page.getSize());System.out.println("总记录数:"+page.getTotal());System.out.println("总页数:"+page.getPages());System.out.println("是否有上一页:"+page.hasPrevious());System.out.println("是否有下一页:"+page.hasNext());}
}

image-20250116135813464

自定义分页

在UserMapper中定义接口方法

java">public interface UserMapper extends BaseMapper<User> {/*** 根据年龄查询用户列表,分页显示* @param page 分页对象 ,xml中可以从里面进行取值 ,传递参数 Page 即自动分页 ,必须放在第一位* @param age 年龄* @return*/IPage<User> selectPageVo(@Param("page") Page<User> page, @Param("age") Integer age);
}

UserMapper.xml中编写SQL

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.qcby.mybatisPlus.mapper.UserMapper"><!-- 定义基础字段 SQL 片段 --><sql id="BaseColumns">uid, username, age, email</sql><!-- 自定义分页查询 --><!--IPage<User> selectPageVo(Page<User> page, Integer age);--><select id="selectPageVo" resultType="com.qcby.mybatisPlus.model.User">SELECT<include refid="BaseColumns"></include>FROM t_userWHERE age > #{age}</select></mapper>

image-20250116140116178

测试

java">@Testpublic void testSelectPageVo() {//设置分页参数Page<User> page = new Page<>(1, 5);userMapper.selectPageVo(page,20);//获取分页数据List<User> list = page.getRecords();list.forEach(System.out::println);System.out.println("自定义分页");System.out.println("当前页:"+page.getCurrent());System.out.println("每页显示的条数:"+page.getSize());System.out.println("总记录数:"+page.getTotal());System.out.println("总页数:"+page.getPages());System.out.println("是否有上一页:"+page.hasPrevious());System.out.println("是否有下一页:"+page.hasNext());}

image-20250116140250995


http://www.ppmy.cn/devtools/152136.html

相关文章

实践深度学习:构建一个简单的图像分类器

引言 深度学习在图像识别领域取得了巨大的成功。本文将指导你如何使用深度学习框架来构建一个简单的图像分类器&#xff0c;我们将以Python和TensorFlow为例&#xff0c;展示从数据准备到模型训练的完整流程。 环境准备 在开始之前&#xff0c;请确保你的环境中安装了以下工…

verilog笔记1

1. 阻塞赋值 阻塞赋值&#xff0c;顾名思义即在一个 always 块中&#xff0c;后面的语句会受到前语句的影响&#xff0c;具体来说就是在同一个always 中&#xff0c;一条阻塞赋值语句如果没有执行结束&#xff0c;那么该语句后面的语句就不能被执行&#xff0c;即被“阻塞”。也…

Java Web开发高级——性能优化与高可用性设计

在现代Web开发中&#xff0c;性能优化和高可用性设计是保障用户体验和业务连续性的重要环节。本文围绕以下三个方面展开&#xff1a;Web应用性能瓶颈分析与优化、数据库连接池与缓存优化、高可用架构设计与负载均衡。通过结合最新技术方案&#xff0c;帮助开发者在实际场景中构…

Java 高级工程师面试高频题:JVM+Redis+ 并发 + 算法 + 框架

前言 在过 2 个月即将进入 3 月了&#xff0c;然而面对今年的大环境而言&#xff0c;跳槽成功的难度比往年高了很多&#xff0c;很明显的感受就是&#xff1a;对于今年的 java 开发朋友跳槽面试&#xff0c;无论一面还是二面&#xff0c;都开始考验一个 Java 程序员的技术功底…

java方法以及与C语言对比学习

目录 方法概述 方法的概念 方法的定义和调用 无参数方法定义和调用 无参数方法例 带参数方法定义和调用 带参数方法定义和调用 参和实参 带参数方法例 如何判断用无参还是有参方法 带返回值方法的定义和调用 带返回值方法定义和调用 带返回值方法练习 方法的注意事…

ctfshow复现2024ciscn第一场web

2024ciscn第一场 本章内容均在ctfshow复现 图片若显示失败请参考我的blog&#x1f447; ddl08.github.io sanic python污染 源码 from sanic import Sanic from sanic.response import text, html from sanic_session import Session import pydash # pydash5.1.2 ​ ​…

latin1_swedish_ci(latin1 不支持存储中文、日文、韩文等多字节字符)

文章目录 1、SHOW TABLE STATUS WHERE Name batch_version;2、latin1_swedish_ci使用场景注意事项修改字符集和排序规则修改表的字符集和排序规则修改列的字符集和排序规则修改数据库的默认字符集和排序规则 3、ALTER TABLE batch_version CONVERT TO CHARACTER SET utf8mb4 C…

JavaScript系列(34)--服务端渲染技术详解

JavaScript服务端渲染技术详解 &#x1f5a5;️ 今天&#xff0c;让我们深入了解JavaScript的服务端渲染技术&#xff0c;这是一种提升Web应用性能和SEO友好性的重要技术。 服务端渲染基础概念 &#x1f31f; &#x1f4a1; 小知识&#xff1a;服务端渲染&#xff08;SSR&…