- 主要是为了减少数据的处理量
1 使用Limit分页
select * from user limit startInde,pageSize
以往可以将最后一个设置成-1表示查询到最后一个,但是现在被修复了。不能使用-1了
使用Mybatis实现分页,核心算sql
1.接口
//实现分页
List<User> getUserByLimit(Map<String,Integer> map);
2.mapper.xml
<!--结果集映射-->
<resultMap id="UserMap" type="User">
<!--column是数据库中的字段,property实体类中的属性-->
<!-- <result column="id" property="id"/>
<result column="name" property="name"/>-->
<result column="pwd" property="password"/>
</resultMap>
<!--实现分页-->
<!--没有做结果集映射都是resultType-->
<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<String, Integer>();
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
<!--结果集映射-->
<resultMap id="UserMap" type="User">
<!--column是数据库中的字段,property实体类中的属性-->
<!-- <result column="id" property="id"/>
<result column="name" property="name"/>-->
<result column="pwd" property="password"/>
</resultMap>
<!--实现分页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.hxl.dao.UserMapper.getUserByRowBounds",null,rowBounds);
System.out.println(userList);
sqlSession.close();
}
3. 分页插件
Mybatis分页插件 PageHelper