1.リミットページングの使用
使用MyBatisのは、ページング、コアを実装するSQL
select * from user limit startIndex,pageSize
-
UserMapperインタフェース
//分页 List<User> getUserByLimit(Map<String,Integer> map);
-
Mapper.xml
<!--分页--> <select id="getUserByLimit" parameterType="map" 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(); }
2、RowBoundsページ
SQL文は、ページングを実装して使用しないでください。
-
UserMapperインタフェース
List<User> getUserByRowBounds();
-
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(0, 2); //通过java代码层面实现分页 List<User> userList = sqlSession.selectList("com.tt.dao.UserMapper.getUserByRowBounds",null,rowBounds); for (User user : userList) { System.out.println(user); } sqlSession.close(); }
3、ページネーションプラグイン
ページネーションプラグインpageherlper用途:公式文書https://pagehelper.github.io/docs/howtouse/