7.1、使用limit实现分页
Mapper接口
/**
* 分页查询
* @param map
* @return
*/
List<User> getUserByLimit(Map<String,Integer> map);
UserMapper.xml
<!--分页查询-->
<select id="getUserByLimit" parameterType="map" resultMap="UserMap">
select * from user limit #{startIndex},#{pageSize}
</select>
Test
/**
* 分页查询
*/
@Test
public void getUserByLimit(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
Map<String,Integer> map = new HashMap<>();
map.put("startIndex",2);
map.put("pageSize",2);
List<User> userList = mapper.getUserByLimit(map);
for (User user : userList) {
System.out.println(user);
}
sqlSession.close();
}
这种分页查询方式是基于SQL语句层进行查询,不具有面向对象的性质,因此我们需要采用一种以面向对象为本质的查询方式
7.2、使用RowBounds实现分页
这是一种不依赖SQL实现分页的方式
Mapper接口:
/**
* RowBounds分页查询
* @return
*/
List<User> getUserByRowBounds();
UserMapper.xml
<!--RowBounds分页查询-->
<select id="getUserByRowBounds" resultMap="UserMap">
select * from user
</select>
Test
@Test
public void getUserByRowBounds(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
//RowBounds实现,从索引为1的开始,向后查2条数据
RowBounds rowBounds = new RowBounds(1, 2);
List<User> list = sqlSession.selectList("org.johngea.mapper.UserMapper.getUserByRowBounds", null, rowBounds);
for (User user : list) {
System.out.println(user);
}
sqlSession.close();
}
7.3、分页插件
PageHelper:https://pagehelper.github.io/docs/howtouse/(官方文档地址)
了解即可,以后公司的架构师说要使用,需要知道它是什么东西