1 分页查询 limit
思考:为什么分页?
- 减少数据的处理量
1.1 使用Limit分页
格式:
SELECT * from user limit startIndex,pageSize
- startIndex 代表起始位置
- pageSize 代表每页的大小
使用MyBatis实现分页,核心SQL
1.接口
//分页
List<User> getUserByLimit(Map<String,Integer> map);
2.Mapper.xml
<!--分页查询-->
<select id="getUserByLimit" parameterType="map" resultMap="UserMap">
select * from 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",1);
map.put("pageSize",2);
List<User> list = mapper.getUserByLimit(map);
for (User user : list) {
System.out.println(user);
}
}
2.2 使用RowBounds分页
不再使用SQL实现分页
1.接口
//分页2
List<User> getUserByRowBounds();
2.mapper.xml
<!--分页查询2-->
<select id="getUserByRowBounds" resultType="com.xgh.pojo.User">
select * from user;
</select>
3.测试
public void getUserByRowBounds(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
//RowBounds实现
RowBounds rowBounds = new RowBounds(1, 2);
//通过Java代码层面实现分页
List<User> userList = sqlSession.selectList("com.xgh.dao.UserMapper.findUserByRowBounds", null, rowBounds);
for (User user : userList) {
System.out.println(user);
}
sqlSession.close();
}
2.3 分页插件
官网:https://pagehelper.github.io/
了解即可