Mybatis分页插件了解一下

简介: Mybatis分页插件了解一下

前言

大家好,一直以来我都本着 用最通俗的话理解核心的知识点, 我认为所有的难点都离不开 基础知识 的铺垫


适合人群

  • 学完Java基础
  • 想通过Java快速构建web应用程序
  • 想学习或了解SpringBoot

大佬可以绕过 ~


背景

如果你是一路看过来的,很高兴你能够耐心看完。之前带大家学了Springboot基础部分,对基本的使用有了初步的认识, 接下来的几期内容将会带大家进阶使用,会先讲解基础中间件的使用和一些场景的应用,或许这些技术你听说过,没看过也没关系,我会带大家一步一步的入门,耐心看完你一定会有收获~


情景回顾

上期带大家学习了Springboot中如何集成redis以及它的一个基本使用, 本期将带大家学习mybatis的一个分页插件的使用,同样的,我们集成到Springboot中。最近github可能会被墙,所以我把源码放到了国内gitee上,本节我们依然使用上期的代码


项目源码(持续更新⭐️)


为什么需要分页?

分页好比你买的书一样,它内容多了,总不能放一页吧,一页也放不下,所以得分页,第一页翻完就翻第二页,所以很好理解。在程序中,一般分页常用于列表的接口比如用户列表、文章列表等等,而列表项的数据一般都返回很简单的数据用于前端展示,详情页一般会展示比较全的一个数据,所以大家写接口的时候可以注意下,不要全部返回数据。有的详情是要带着权限去查询的,如果列表就返回了全部数据,万一对方是个懂技术的,不就曝光了表里的全部数据了。


我们再说一下分页的算法, 分页里主要有两个变量一个是page, 另一个是pageSize,一般由前端传过来,服务端会接收这两个数值,在接收的时候要判断一下,如果对方为空或者0,你可以设置一个基础值比如page=1, pageSize=10,不至于用户看到的是空列表

其实分页,在sql中就可以做分页功能了,之前讲mysql没给大家介绍,主要是想结合这一节一起讲。那么sql怎么做分页呢?以之前的用户角色列表为例:

SELECT * from user_role LIMIT 10 OFFSET 0
复制代码


同样的,主要是limit, offset这两个值, 第一个很好理解,限制数量,就是一页多少个数据,第二个也很好理解,位移,就是向下位移多少条数据,一般可以通过如下公式计算:

limit = pageSize
offset = pageSize * (page -1)
复制代码


很简单的数学题,不要说不会 ~


使用sql进行分页

好,有了以上基础,大家可以自行试一下,在**Mapper.xml写一下试试,这种方式也是可以的, 下面给大家介绍个神器


集成分页插件

同样的,修改一下我们的pom.xml

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


怎么使用?

这里直接帮大家封装好,因为一般列表项数据主要涉及几个属性, list(数据)total(总条数), pageSize(一页多少条), pageNum(当前第几页),主要涉及这几项,因为前端一般也会根据这几个值,进行列表,页码的一个展示,好,我们直接看代码:

public class CommonPage<T> {
    private Integer pageNum;
    private Integer pageSize;
    private Long total;
    private List<T> list;
    /**
     * 将PageHelper分页后的list转为分页信息
     */
    public static <T> CommonPage<T> restPage(List<T> list) {
        CommonPage<T> result = new CommonPage<T>();
        PageInfo<T> pageInfo = new PageInfo<T>(list);
        result.setPageNum(pageInfo.getPageNum());
        result.setPageSize(pageInfo.getPageSize());
        result.setTotal(pageInfo.getTotal());
        result.setList(pageInfo.getList());
        return result;
    }
    public static void setPageHelper(Integer pageNum, Integer pageSize) {
        if(pageNum == null || pageNum <= 0) {
            pageNum = 1;
        }
        if(pageSize == null || pageSize <= 0) {
            pageSize = 10;
        }
        if(pageSize >= 20) {
            pageSize = 20;
        }
        PageHelper.startPage(pageNum, pageSize);
    }
    public Integer getPageNum() {
        return pageNum;
    }
    public void setPageNum(Integer pageNum) {
        this.pageNum = pageNum;
    }
    public Integer getPageSize() {
        return pageSize;
    }
    public void setPageSize(Integer pageSize) {
        this.pageSize = pageSize;
    }
    public List<T> getList() {
        return list;
    }
    public void setList(List<T> list) {
        this.list = list;
    }
    public Long getTotal() {
        return total;
    }
    public void setTotal(Long total) {
        this.total = total;
    }
}
复制代码


然后,我们去调用它, 修改我们之前写的列表:

@GetMapping("role/list")
@ResponseBody
public CommonPage<UserRole> getUserRole() {
    CommonPage.setPageHelper(1, 10);
    List<UserRole> list = userRoleMapper.getRoles();
    return  CommonPage.restPage(list);
}
复制代码


请求成功后会返回如下:

{
    "pageNum": 1,
    "pageSize": 10,
    "total": 1,
    "list": [
        {
            "id": 1,
            "name": "普通用户123",
            "roleName": "普通用户"
        }
    ]
}
复制代码

其实它的原理,也是对sql进行了改写,进行了sql查询, 底层主要依赖mybatis的拦截器进行实现的, 这里不给大家过多深入讲解,后边会给大家介绍,我们先熟练掌握它的一个基本使用。


结束语

本期就到这里结束了,总结一下,本节主要带大家学习了sql如何进行分页查询和介绍了mybatis 分页插件的基本使用,建议大家多去试着写写


下期预告

下期带大家学习springboot中,如何处理跨域问题, 如果你不知道啥事跨域,我会从头说起。 我们下期不见不散, 关注我,不迷路~

相关文章
|
3月前
|
SQL XML Java
8、Mybatis-Plus 分页插件、自定义分页
这篇文章介绍了Mybatis-Plus的分页功能,包括如何配置分页插件、使用Mybatis-Plus提供的Page对象进行分页查询,以及如何在XML中自定义分页SQL。文章通过具体的代码示例和测试结果,展示了分页插件的使用和自定义分页的方法。
8、Mybatis-Plus 分页插件、自定义分页
|
18天前
|
SQL Java 数据库连接
深入 MyBatis-Plus 插件:解锁高级数据库功能
Mybatis-Plus 提供了丰富的插件机制,这些插件可以帮助开发者更方便地扩展 Mybatis 的功能,提升开发效率、优化性能和实现一些常用的功能。
107 26
深入 MyBatis-Plus 插件:解锁高级数据库功能
|
9天前
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
18天前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
1月前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
56 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
2月前
|
SQL Java 数据库连接
解决mybatis-plus 拦截器不生效--分页插件不生效
本文介绍了在使用 Mybatis-Plus 进行分页查询时遇到的问题及解决方法。依赖包包括 `mybatis-plus-boot-starter`、`mybatis-plus-extension` 等,并给出了正确的分页配置和代码示例。当分页功能失效时,需将 Mybatis-Plus 版本改为 3.5.5 并正确配置拦截器。
670 6
解决mybatis-plus 拦截器不生效--分页插件不生效
|
2月前
|
SQL XML Java
springboot整合mybatis-plus及mybatis-plus分页插件的使用
这篇文章介绍了如何在Spring Boot项目中整合MyBatis-Plus及其分页插件,包括依赖引入、配置文件编写、SQL表创建、Mapper层、Service层、Controller层的创建,以及分页插件的使用和数据展示HTML页面的编写。
springboot整合mybatis-plus及mybatis-plus分页插件的使用
|
3月前
|
SQL Java 关系型数据库
MyBatis-Plus 分页魅力绽放!紧跟技术热点,带你领略数据分页的高效与便捷
【8月更文挑战第29天】在 Java 开发中,数据处理至关重要,尤其在大量数据查询与展示时,分页功能尤为重要。MyBatis-Plus 作为一款强大的持久层框架,提供了便捷高效的分页解决方案。通过封装数据库分页查询语句,开发者能轻松实现分页功能。在实际应用中,只需创建 `Page` 对象并设置页码和每页条数,再通过 `QueryWrapper` 构建查询条件,调用 `selectPage` 方法即可完成分页查询。MyBatis-Plus 不仅生成分页 SQL 语句,还自动处理参数合法性检查,并支持条件查询和排序等功能,极大地提升了系统性能和稳定性。
56 0
|
1月前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
116 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
1月前
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
333 1
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个