zoukankan      html  css  js  c++  java
  • 7、MyBatis教程之分页实现

    8、分页实现

    1、limit实现分页

    思考:为什么需要分页?

    在学习mybatis等持久层框架的时候,会经常对数据进行增删改查操作,使用最多的是对数据库进行查询操作,如果查询大量数据的时候,我们往往使用分页进行查询,也就是每次处理小部分数据,这样对数据库压力就在可控范围内。

    使用Limit实现分页

    #语法
    SELECT * FROM table LIMIT stratIndex,pageSize
    
    SELECT * FROM table 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。 
    

    步骤:

    1、修改Mapper文件

    <select id="getUserByPage" parameterType="map" resultType="user">
      select * from user limit #{startIndex},#{pageSize}
    </select>
    

    2、Mapper接口,参数为map

    //选择全部用户实现分页
    List<User> getUserByPage(Map<String,Integer> map);
    

    3、在测试类中传入参数测试

    • 推断:起始位置 = (当前页面 - 1 ) * 页面大小
    //分页查询 , 两个参数startIndex , pageSize
    @Test
    public void testSelectUser() {
       SqlSession session = MybatisUtils.getSession();
       UserMapper mapper = session.getMapper(UserMapper.class);
    
       int currentPage = 1;  //第几页
       int pageSize = 2;  //每页显示几个
       Map<String,Integer> map = new HashMap<String,Integer>();
       map.put("startIndex",(currentPage-1)*pageSize);
       map.put("pageSize",pageSize);
    
       List<User> users = mapper.getUserByPage(map);
    
       for (User user: users){
           System.out.println(user);
      }
    
       session.close();
    }
    

    2、RowBounds分页

    我们除了使用Limit在SQL层面实现分页,也可以使用RowBounds在Java代码层面实现分页,当然此种方式作为了解即可。我们来看下如何实现的!

    步骤:

    1、mapper接口

    //选择全部用户RowBounds实现分页
    List<User> getUserByRowBounds();
    

    2、mapper文件

    <select id="getUserByRowBounds" resultType="user">
    select * from user
    </select>
    

    3、测试类

    在这里,我们需要使用RowBounds类

    @Test
    public void testUserByRowBounds() {
       SqlSession session = MybatisUtils.getSession();
    
       int currentPage = 2;  //第几页
       int pageSize = 2;  //每页显示几个
       RowBounds rowBounds = new RowBounds((currentPage-1)*pageSize,pageSize);
    
       //通过session.**方法进行传递rowBounds,[此种方式现在已经不推荐使用了]
       List<User> users =session.selectList("com.kuang.mapper.UserMapper.getUserByRowBounds", null,rowBounds);
    
       for (User user: users){
           System.out.println(user);
      }
       session.close();
    }
    

    3、其他分页插件

    PageHelper

    img

    了解即可,可以自己尝试使用

    官方文档:https://pagehelper.github.io/

  • 相关阅读:
    java设计模式之适配器模式
    在Eclipse中建立Maven Web项目
    java设计模式之原型模式
    java设计模式之建造者模式
    java设计模式之工厂模式
    java设计模式之单例模式
    C# 前端多次上传文件
    C# async 和 await
    .NET 4.0 任务(Task)
    C# 5.0
  • 原文地址:https://www.cnblogs.com/chenn/p/13345391.html
Copyright © 2011-2022 走看看