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 实现
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构