Mybatis学习笔记七之分页查询

    科技2024-07-11  174

    7、分页

    思考:为什么要分页?

    减少数据的处理量

    7.1、使用Limit分页

    语法:SELECT * from user limit startIndex,pageSize; SELECT * from user limit 5,10; // 检索记录行 6-15 #为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1: SELECT * FROM table LIMIT 95,-1; // 检索记录行 96-last. #如果只给定一个参数,它表示返回最大的记录行数目: SELECT * FROM table LIMIT 5; //检索前 5 个记录行 #换句话说,LIMIT n 等价于 LIMIT 0,n。

    使用Mybatis实现分页,核心SQL

    接口

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

    Mapper.xml

    <!--//分页--> <select id="getUserByLimit" parameterType="map" resultType="user"> 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<String, Integer>(); map.put("startIndex",1); map.put("pageSize",2); List<User> userList = mapper.getUserByLimit(map); for (User user : userList) { System.out.println(user); } sqlSession.close(); }

    7.2、RowBounds分页

    不再使用SQL实现分页

    接口

    //分页2 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(1, 2); //通过Java代码层面实现分页 List<User> userList = sqlSession.selectList("com.kuang.dao.UserMapper.getUserByRowBounds",null,rowBounds); for (User user : userList) { System.out.println(user); } sqlSession.close(); } }

    运行结果

    Processed: 0.015, SQL: 8