7. Pagination
Thinking: Why pagination?
Reduce the amount of data processed
7.1 Use Limit pagination
SELECT * from user limit startIndex,pageSize
Use Mybatis to implement paging, core SQL
1. Interface
//分页
List<User> getUserByLimit(Map<String,Integer> map);
2.Mapper.XML
<!--分页查询-->
<select id="getUserByLimit" parameterType="map" resultMap="UserMap">
select * from mybatis.user limit #{startIndex},#{pageSize}
</select>
3. Test
@Test
public void getUserBylimit(){
SqlSession sqlSesssion = MybatisUtils.getSqlSesssion();
UserMapper mapper = sqlSesssion.getMapper(UserMapper.class);
HashMap<String, Integer> map = new HashMap<String, Integer>();
map.put("startIndex",0);
map.put("pageSize",2);
List<User> userlist = mapper.getUserByLimit(map);
for (User user: userlist) {
System.out.println(user);
}
sqlSesssion.close();
}
7.2、RowBounds
No longer use SQL to implement pagination
1. Interface
//分页2
List<User> getUserByRowBounds();
2.mapper.xml
<!--分页查询2-->
<select id="getUserByRowBounds">
select * from user limit #{startIndex},#{pageSize}
</select>
3. Test
public void getUserByRowBounds(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
//RowBounds实现
RowBounds rowBounds = new RowBounds(1, 2);
//通过Java代码层面实现分页
List<User> userList = sqlSession.selectList("com.jiang.dao.UserMapper.getUserByRowBounds", null, rowBounds);
for (User user : userList) {
System.out.println(user);
}
sqlSession.close();
}
7.3. Pagination plug-in