使用Limit分页
前期使用LImit分页
语法:SELECT *FROM user limit startIndex,pageSize;
SELECT *FROM user limit 3; #[0.n]
使用Mybatus实现分页,核心SQL
-
接口
//分页 List<User> getUserByLimit(Map<String,Integer> map);
-
Mapper.xml
<!-- 分页--> <select id="getUserByLimit" parameterType="map" resultType="user" resultMap="UserMap"> select *from mybatis.user limit #{startIndex},#{pageSize} </select>
-
测试
@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(); } ========================================================================================================= print: ==> Preparing: select *from mybatis.user limit ?,? ==> Parameters: 0(Integer), 2(Integer) <== Columns: id, name, pwd <== Row: 1, zrk, 123 <== Row: 2, zq, 456 <== Total: 2 User{id=1, name='zrk', password='123'} User{id=2, name='zq', password='456'}
RowBounds分页(不推荐)
不再使用SQL实现分页,使用对象
-
接口
List<User> getUserByRowBounds(Map<String,Integer> map);
-
Mapper.xml
<!-- 分页2--> <select id="getUserByRowBounds" resultMap="UserMap"> select *from mybatis.user </select>
-
测试
@Test public void getUserByRowBounds(){ SqlSession sqlSession = MybatisUtils.getSqlSession(); //RowBounds实现 RowBounds rowBounds = new RowBounds(1, 2); //通过Java代码层面实现分页 List<User> userList = sqlSession.selectList("com.vekzjj.dao.UserMapper.getUserByRowBounds",null,rowBounds); for (User user : userList) { System.out.println(user); } sqlSession.close(); }