mybatis-分页查询

第一种方式:使用 Limit 实现

第一步:编写 UserMapper 接口 中的方法

//limit分页实现
List<User> getUserByLimit(Map<String,Integer> map);

第二步:编写 UserMapper.xml 中的 Sql 实现

<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);
    Map<String,Integer> map = new HashMap<>();
    map.put("startIndex",0);
    map.put("pageSize",3);
    List<User> userList = mapper.getUserByLimit(map);
    for (User user : userList) {
        System.out.println(user);
    }
    sqlSession.close();
}

第二种方式:使用 RowBounds 实现

第一步:编写 UserMapper 接口 中的方法

//rowBounds分页实现
List<User> getUserByRowBounds();

第二步:编写 UserMapper.xml 中的 Sql 实现

<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.lv.com.lv.dao.UserMapper.getUserByRowBounds",null,rowBounds);
    for (User user : userList) {
        System.out.println(user);
    }
    sqlSession.close();
}

第三种方式:使用插件 PageHelper 实现

官网地址:MyBatis 分页插件 PageHelper

posted @ 2022-01-06 11:16  从0开始丿  阅读(593)  评论(0编辑  收藏  举报