MyBatis的pageHelper分页插件的使用(十五)下

简介: MyBatis的pageHelper分页插件的使用(十五)

四. MyBatis自带的 RowBounds 进行分页


四.一 RowBounds 类


package org.apache.ibatis.session;
       public class RowBounds
       {
         public static final int NO_ROW_OFFSET = 0;
         public static final int NO_ROW_LIMIT = Integer.MAX_VALUE;
         public static final RowBounds DEFAULT = new RowBounds();
         private final int offset;
         private final int limit;
         public RowBounds()
         {
          offset = 0;
           limit = Integer.MAX_VALUE;
         }
         public RowBounds(int offset, int limit) {
             this.offset = offset;
            this.limit = limit;
         }
         public int getOffset() {
           return offset;
         }
         public int getLimit() {
          return limit;
         }
       }


RowBounds 有两个属性, offset 和limit 。其中,offset默认为0,limit 默认为Integer 的最大值。


没有setter和getter 方法, 只能在构造时使用。 (MyBatis用的是offset和limit, 老蝴蝶前面用的是 start 和offset)


四.二 使用RowBounds 进行分页


UserMapper.java 接口:


//根据RowBounds 进行相应的分页
    List<User> selectForRow(UserExample example,RowBounds row);


UserMapper.xml 语句:


语句与前面的一样,不具有侵入性。 不用改变相应的sql语句。 只需要在要分页的方法接口上添加 RowBounds 对象参数即可。


 <!-- rowBounds 进行分页查询 -->
    <select id="selectForRow" resultMap="BaseResultMap" parameterType="com.yjl.pojo.UserExample" >
    select
    <if test="distinct" >
      distinct
    </if>
    <include refid="Base_Column_List" />
    from user
    <if test="_parameter != null" >
      <include refid="Example_Where_Clause" />
    </if>
    <if test="orderByClause != null" >
      order by ${orderByClause}
    </if>
  </select>


测试方法:


@Test
  public void test2(){
    SqlSession sqlSession=SqlSessionFactoryUtils.getSession();
    UserMapper userMapper=sqlSession.getMapper(UserMapper.class); 
    UserExample example=new UserExample();
    example.setOrderByClause("id asc");
    //页数, 最大显示数。
    int page=2;
    int rowNum=5;
    int start=(page-1)*rowNum;
    RowBounds row=new RowBounds(start,rowNum); //会查询出全部的结果,然后再进行挑选分页。
    List<User> allUser=userMapper.selectForRow(example,row);
    allUser.forEach(n ->System.out.println(n));
  }


运行


20190719142245570.png


会发现有一个很大的问题, 内部的查询sql 语句是全部查询,是先查询出来完,然后再利用RowBounds 进行挑选性的分页。 数据量小时还可以,数据量多时,就不能使用了。


故,最好的方式还是利用pageHelper 的分页插件。


五. pageHelper 分页插件


pageHelper 插件,托管于 github, 地址是:https://github.com/pagehelper/Mybatis-PageHelper


有一个中文的帮助文档:


2019071914231066.png


地址:


https://github.com/pagehelper/Mybatis-PageHelper/blob/master/wikis/zh/HowToUse.md


这里只讲解最基本的用法,与Maven 和Spring 整合使用的,不讲。


五.一 下载jar包


下载这两个jar包, 把它们添加到classpath 路径下。


20190719142320921.png


两个都要放置,否则会出错。


一般人常常放置 pageHelper 的jar包,并没有放置 jsqlparser-2.1.jar 的包,是错误的,会报下面的错误。


20190719142329514.png


五.二 在SqlMapConfig.xml 中配置插件


<!-- 放置在别名之后,环境之前 -->
  <plugins>
    <!-- 分页插件,引入拦截器 -->
    <plugin interceptor="com.github.pagehelper.PageInterceptor">
      <!-- 指定数据库为mysql,虽然会自动监测。 -->
      <property name="helperDialect" value="mysql"/>
    </plugin>
  </plugins>


五.三 pageHelper 分页与RowBounds 连用


运行test3() 方法,监测selectForRow()的接口,这个时候,添加了pageHelper插件后的控制台为:


20190719142351531.png


会直接查询 limit. 但一般不这么做。


五.四 pageHelper的 startPage()方法或者offsetPage() 方法


其中,startPage() 方法和offsetPage() 的用法是不一样的。


测试方法:


@Test
  public void test4(){
    SqlSession sqlSession=SqlSessionFactoryUtils.getSession();
    UserMapper userMapper=sqlSession.getMapper(UserMapper.class); 
    UserExample example=new UserExample();
    example.setOrderByClause("id asc");
    //页数, 最大显示数。
    int page=2;
    int rowNum=5;
    int start=(page-1)*rowNum;
    //PageHelper.startPage(page,rowNum);  //开始的页数和数目
    PageHelper.offsetPage(start,rowNum); //开始处和数目
    List<User> allUser=userMapper.selectByExample(example);
    allUser.forEach(n ->System.out.println(n));
  }


控制台打印输出。


2019071914235978.png


pageHelper插件还有更多的用法,具体的可参考文档,文档很详细,这里就不一一讲解了。


谢谢!!!

相关文章
|
1月前
|
SQL Java 数据库连接
MyBatis分页
MyBatis作为Java持久层框架,需结合数据库特性或插件实现分页。分页分为物理分页(如MySQL的LIMIT)和逻辑分页(内存截取),推荐使用PageHelper插件自动注入分页语句,提升开发效率与性能。需注意索引优化、深分页问题及多表关联时的兼容性,结合业务场景选择合适方案。
98 4
|
7月前
|
SQL Java 数据库连接
微服务——MyBatis分页
本文介绍了分页的多种实现方式,包括自带RowBounds分页、第三方插件PageHelper分页、SQL分页、数组分页及拦截器分页。其中,RowBounds是先查询全部结果再内存分页;PageHelper通过修改SQL动态添加分页关键字;SQL分页依赖数据库自身的分页功能如`LIMIT`;数组分页则是查询全量数据后用`subList`方法截取;拦截器分页则统一在SQL后添加分页语句。最后总结逻辑分页适合小数据量,但大数据量易内存溢出;物理分页虽小数据量效率较低,但更适合大数据场景,优先推荐使用。
97 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`注解完成整合
729 1
Spring boot 使用mybatis generator 自动生成代码插件
|
5月前
|
SQL Java 数据安全/隐私保护
发现问题:Mybatis-plus的分页总数为0,分页功能失效,以及多租户插件的使用。
总的来说,使用 Mybatis-plus 确实可以极大地方便我们的开发,但也需要我们理解其工作原理,掌握如何合适地使用各种插件。分页插件和多租户插件是其中典型,它们的运用可以让我们的代码更为简洁、高效,理解和掌握好它们的用法对我们的开发过程有着极其重要的意义。
565 15
|
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 方法实现自动分页。
|
7月前
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
599 0