思考:为嘛要分页?
——为了减少数据的处理量
1. 使用Limit分页
语法:select * from user limit startIndex,pageSize;select * from user limit 3; (默认从0开始,显示数据量为3 --> #[ 0 , n ])
使用mybatis实现分页,核心SQL:
1. 接口
// 分页
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
public void getUserByLimit(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
HashMap<String, Integer> map = new HashMap<>();
map.put("startIndex",0);
map.put("pageSize",2);
List<User> userList = mapper.getUserByLimit(map);
for (User user : userList) {
System.out.println(user);
}
sqlSession.close();
}
2. 使用RowBounds分页
不再使用SQL实现分页
1. 接口
// 分页2
List<User> getUserByRowBounds();
2. mapper.xml
<!--//分页2-->
<select id="getUserByRowBounds" resultMap="UserMap">
select * from mybatis.user
</select>
3. 测试
@Test
public void getUserByRowBounds(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
// 通过RowBounds实现
RowBounds rowBounds = new RowBounds(1, 2);
// 通过java代码层面实现分页
List<User> userList = sqlSession.selectList("com.yang.dao.UserMapper.getUserByRowBounds",null,rowBounds);
for (User user : userList) {
System.out.println(user);
}
sqlSession.close();
}