减少数据处理量,提升效率
1. limit 分页
select * from mybatis.user limit startIndex,pageSize;
select * from mybatis.user limit n; #[0,n]
MyBatis实现分页
-
接口
//分页 List<User> getUserByLimit(Map<String,Integer> map);
-
Mapper.xml
<!--结果集映射--> <resultMap id="UserMap" type="User"> <!--column数据库中的字段 property实体类中的属性--> <result column="name" property="username"/> </resultMap> <!--分页查询--> <select id="getUserByLimit" parameterType="map" resultMap="UserMap"> select * from mybatis.user limit #{startIndex},#{pageSize} </select>
-
测试
@Test public void getUserByLimit(){ SqlSession sqlSession = MyBatisUntils.getSqlSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class); HashMap<String, Integer> map = new HashMap<String, Integer>(); map.put("startIndex",4); map.put("pageSize",3); List<User> userList = mapper.getUserByLimit(map); for (User user : userList) { System.out.println(user); } sqlSession.close(); }
2. RowBounds 分页
不建议使用
-
接口
//分页 RowBounds List<User> getUserByRowBounds();
-
Mapper.xml
<!--RowBounds分页查询--> <select id="getUserByRowBounds" resultMap="UserMap"> select * from mybatis.user </select>
-
测试
@Test public void getUserByRowBounds(){ SqlSession sqlSession = MyBatisUntils.getSqlSession(); //RowBounds RowBounds rowBounds = new RowBounds(1, 3); //Java层面实现分页 List<User> userlist = sqlSession.selectList("com.yl.dao.UserMapper.getUserByRowBounds",null,rowBounds); for (User user : userlist) { System.out.println(user); } sqlSession.close(); }
3. 分页插件
https://pagehelper.github.io/