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插件还有更多的用法,具体的可参考文档,文档很详细,这里就不一一讲解了。


谢谢!!!

相关文章
|
15天前
|
SQL Java 数据库连接
深入 MyBatis-Plus 插件:解锁高级数据库功能
Mybatis-Plus 提供了丰富的插件机制,这些插件可以帮助开发者更方便地扩展 Mybatis 的功能,提升开发效率、优化性能和实现一些常用的功能。
95 26
深入 MyBatis-Plus 插件:解锁高级数据库功能
|
5天前
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
14天前
|
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文档,同时定义了统一的数据返回格式和请求模块。
54 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 并正确配置拦截器。
606 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分页插件的使用
|
1月前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
108 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
1月前
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
300 1
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
|
1月前
|
SQL Java 数据库连接
mybatis使用二:springboot 整合 mybatis,创建开发环境
这篇文章介绍了如何在SpringBoot项目中整合Mybatis和MybatisGenerator,包括添加依赖、配置数据源、修改启动主类、编写Java代码,以及使用Postman进行接口测试。
17 0
mybatis使用二:springboot 整合 mybatis,创建开发环境
|
1月前
|
Java 数据库连接 API
springBoot:后端解决跨域&Mybatis-Plus&SwaggerUI&代码生成器 (四)
本文介绍了后端解决跨域问题的方法及Mybatis-Plus的配置与使用。首先通过创建`CorsConfig`类并设置相关参数来实现跨域请求处理。接着,详细描述了如何引入Mybatis-Plus插件,包括配置`MybatisPlusConfig`类、定义Mapper接口以及Service层。此外,还展示了如何配置分页查询功能,并引入SwaggerUI进行API文档生成。最后,提供了代码生成器的配置示例,帮助快速生成项目所需的基础代码。