四. 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)); }
运行
会发现有一个很大的问题, 内部的查询sql 语句是全部查询,是先查询出来完,然后再利用RowBounds 进行挑选性的分页。 数据量小时还可以,数据量多时,就不能使用了。
故,最好的方式还是利用pageHelper 的分页插件。
五. pageHelper 分页插件
pageHelper 插件,托管于 github, 地址是:https://github.com/pagehelper/Mybatis-PageHelper
有一个中文的帮助文档:
地址:
https://github.com/pagehelper/Mybatis-PageHelper/blob/master/wikis/zh/HowToUse.md
这里只讲解最基本的用法,与Maven 和Spring 整合使用的,不讲。
五.一 下载jar包
下载这两个jar包, 把它们添加到classpath 路径下。
两个都要放置,否则会出错。
一般人常常放置 pageHelper 的jar包,并没有放置 jsqlparser-2.1.jar 的包,是错误的,会报下面的错误。
五.二 在SqlMapConfig.xml 中配置插件
<!-- 放置在别名之后,环境之前 --> <plugins> <!-- 分页插件,引入拦截器 --> <plugin interceptor="com.github.pagehelper.PageInterceptor"> <!-- 指定数据库为mysql,虽然会自动监测。 --> <property name="helperDialect" value="mysql"/> </plugin> </plugins>
五.三 pageHelper 分页与RowBounds 连用
运行test3() 方法,监测selectForRow()的接口,这个时候,添加了pageHelper插件后的控制台为:
会直接查询 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)); }
控制台打印输出。
pageHelper插件还有更多的用法,具体的可参考文档,文档很详细,这里就不一一讲解了。
谢谢!!!