码迷,mamicode.com
首页 > 其他好文 > 详细

mybatis学习(六、分页)

时间:2021-03-02 12:37:15      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:index   ssi   pre   处理   str   help   app   select   owb   

六、分页

为什么要分页?

  • 减少数据的处理量

1.使用limit分页

语法:SELECT * FROM user LIMIT startIndex,pageSize;
SELECT * FROM user LIMIT 0,2;	从第0行开始查2个

使用mybatis实现分页,核心就是sql

  1. 接口

    //分页查询
    List<User> getUserByLimit(Map<String,Integer> map);
    
  2. Mapper.xml

    <!--分页-->
    <select id="getUserByLimit" parameterType="map" resultMap="UserMap">
        select * from mybatis.user limit #{startIndex},#{pageSize}
    </select>
    
  3. 测试

    @Test
    public void testGetUserLimit(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        Map<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实现分页

  1. 接口

    //RowBounds分页查询
    List<User> getUserByRowBounds();
    
  2. Mapper.xml

    <!--分页-->
    <select id="getUserByRowBounds" resultMap="UserMap">
        select * from mybatis.user
    </select>
    
  3. 测试

    @Test
    public void testGetUserByRowBounds(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        //RowBounds实现
        RowBounds rowBounds = new RowBounds(0, 2);
    
        //通过java代码层面实现分页
        List<User> userList = sqlSession.selectList("com.lzt.dao.UserMapper.getUserByRowBounds",null,rowBounds);
    
    
        sqlSession.close();
    }
    

3.分页插件

MyBatis 分页插件 PageHelper

https://pagehelper.github.io/

大型复杂项目中使用,具体进官方文档中查看,有详细使用教程

mybatis学习(六、分页)

标签:index   ssi   pre   处理   str   help   app   select   owb   

原文地址:https://www.cnblogs.com/LiuOneZero/p/14467176.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!