思考:为什么要分页?
- 减少数据的处理量
1、使用limit分页(推荐)
limit子句用于限制查询结果返回的数量。
用法:【select * from tableName limit i,n 】
参数:
- tableName : 为数据表;
- i : 为查询结果的索引值(默认从0开始);
- n : 为查询结果返回的数量.
使用mybatis实现分页
-
接口;
//分页 List<User> getUserByLimit(Map<String,Integer> map);
-
Mapper.xml;
<select id="getUserByLimit" parameterType="map" resultMap="UserMap"> select * from user limit #{startIndex},#{pageSize} </select>
-
测试
@Test public void getUserByLimit(){ SqlSession sqlSession = MyBatisUtil.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> userList = mapper.getUserByLimit(map); for (User user:userList) { System.out.println(user); } sqlSession.close(); }
2、RowBounds分页
思想:面向对象
-
接口;
//分页2 List<User> getUserByRowBounds();
-
Mapper.xml;
<!--分页2--> <select id="getUserByRowBounds" resultMap="UserMap"> select * from user </select>
-
测试
@Test public void getUserByRowBounds(){ SqlSession sqlSession = MyBatisUtil.getSqlSession(); //RowBounds实现 RowBounds rowBounds = new RowBounds(1, 2); List<User> userList = sqlSession.selectList("com.beyond.dao.UserMapper.getUserByRowBounds",null,rowBounds); for (User user:userList) { System.out.println(user); } sqlSession.close(); }
3、分页插件
https://pagehelper.github.io/