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中,如何处理跨域问题, 如果你不知道啥事跨域,我会从头说起。 我们下期不见不散, 关注我,不迷路~

相关文章
|
1月前
|
SQL Java 数据库连接
MyBatis分页
MyBatis作为Java持久层框架,需结合数据库特性或插件实现分页。分页分为物理分页(如MySQL的LIMIT)和逻辑分页(内存截取),推荐使用PageHelper插件自动注入分页语句,提升开发效率与性能。需注意索引优化、深分页问题及多表关联时的兼容性,结合业务场景选择合适方案。
99 4
|
7月前
|
SQL Java 数据库连接
微服务——MyBatis分页
本文介绍了分页的多种实现方式,包括自带RowBounds分页、第三方插件PageHelper分页、SQL分页、数组分页及拦截器分页。其中,RowBounds是先查询全部结果再内存分页;PageHelper通过修改SQL动态添加分页关键字;SQL分页依赖数据库自身的分页功能如`LIMIT`;数组分页则是查询全量数据后用`subList`方法截取;拦截器分页则统一在SQL后添加分页语句。最后总结逻辑分页适合小数据量,但大数据量易内存溢出;物理分页虽小数据量效率较低,但更适合大数据场景,优先推荐使用。
98 0
|
7月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
|
4月前
|
Java 数据库连接 数据库
Spring boot 使用mybatis generator 自动生成代码插件
本文介绍了在Spring Boot项目中使用MyBatis Generator插件自动生成代码的详细步骤。首先创建一个新的Spring Boot项目,接着引入MyBatis Generator插件并配置`pom.xml`文件。然后删除默认的`application.properties`文件,创建`application.yml`进行相关配置,如设置Mapper路径和实体类包名。重点在于配置`generatorConfig.xml`文件,包括数据库驱动、连接信息、生成模型、映射文件及DAO的包名和位置。最后通过IDE配置运行插件生成代码,并在主类添加`@MapperScan`注解完成整合
746 1
Spring boot 使用mybatis generator 自动生成代码插件
|
5月前
|
SQL Java 数据安全/隐私保护
发现问题:Mybatis-plus的分页总数为0,分页功能失效,以及多租户插件的使用。
总的来说,使用 Mybatis-plus 确实可以极大地方便我们的开发,但也需要我们理解其工作原理,掌握如何合适地使用各种插件。分页插件和多租户插件是其中典型,它们的运用可以让我们的代码更为简洁、高效,理解和掌握好它们的用法对我们的开发过程有着极其重要的意义。
574 15
|
8月前
|
监控 安全 数据库
【YashanDB 知识库】Mybatis-Plus 调用 YashanDB 怎么设置分页
数据库状态分为正常与异常两种情况。当出现异常时,首先查看告警列表确认问题(如实例无法连接),并尝试用数据库用户名和密码登录。若能登录,说明主实例故障已切换至备库;若无法登录或为单节点,则需进一步排查。接着检查监控项,若有数据表明主实例故障,无数据则可能是通信中断。随后检查主机上的服务是否存在,若存在但通信受限,需排查安全设置或网络;若服务不存在,可能因重启或断电导致,需手动启动相关服务。最终在YashanDB列表中确认状态恢复。
|
7月前
|
SQL Java 关系型数据库
MyBatis篇-分页
本文介绍了多种分页方式,包括自带rowbound内存分页、第三方插件pagehelper(通过修改SQL实现分页)、SQL分页(依赖limit或rownum等关键字)、数组分页(先查询全部数据再用subList分页)、拦截器分页(自定义拦截器为SQL添加分页语句)。最后总结了逻辑分页(内存分页,适合小数据量)和物理分页(直接在数据库层面分页,适合大数据量)的优缺点,强调物理分页优先于逻辑分页。
|
7月前
|
SQL Java 数据库连接
MyBatis 实现分页的机制
MyBatis 的分页机制主要依赖于 `RowBounds` 对象和分页插件。`RowBounds` 实现内存分页,适合小数据量场景,通过设定偏移量和限制条数对结果集进行筛选。而针对大数据量,则推荐使用分页插件(如 PageHelper),实现物理分页。插件通过拦截 SQL 执行,动态修改语句添加分页逻辑,支持多种数据库方言。配置插件后,无需手动调整查询方法即可完成分页操作,提升性能与灵活性。
155 0
|
7月前
|
Oracle 关系型数据库 Java
|
8月前
|
Oracle 关系型数据库 MySQL
【YashanDB 知识库】Mybatis-Plus 调用 YashanDB 怎么设置分页
**Mybatis-Plus 自动分页配置问题简介** Mybatis-Plus 是 Mybatis 的增强工具,简化 CRUD 操作并适配多种数据库,包括 YashanDB。自动分页配置错误会导致应用开发受影响。解决方法:1. 配置 pagehelper 为 oracle 或 mysql;2. 设置分页拦截器为 oracle 或 mysql。确保返回设置后的对象。正确配置后可在 service 层使用 page 方法实现自动分页。