栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

limit实现分页以及RowBounds分页

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

limit实现分页以及RowBounds分页

limit分页在这之前学习servlet就实现过
select * from table_name limit startIndex,pagesize
再由简易的算法实现 每次点击下一页来更改pagesize以及startIndex的值。

为什么需要分页?

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

之前MySQL修复的bug
select * from table_name limit 3,-1
-1在未修复时 是可以作为查询的最大页数 也是可以查处结果的,修复之后 这样的写法会报错。

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。

mapper增加方法:

 List limiter(Map map);

.xml:

  
        select * from hero limit #{StartIndex},#{pagesize}
    

@test:

@Test
public void limitSelect()
{
    SqlSession sqlSession=MyBatisTool.getSqlSession();
    HeroDAO heroDAO=sqlSession.getMapper(HeroDAO.class);
    Map map=new HashMap();
    map.put("StartIndex",0);
    map.put("pagesize",2);
    List hero=heroDAO.limiter(map);
    for(heros heri:hero)
    {
        System.out.println(heri);
    }

    sqlSession.close();
}

进行分页时一般计算公式—— 起始位置 = (当前页面 - 1 ) * 页面大小

RowBounds分页
RowBounds 实质为一个类 使用时实例化一个对象 传入即可 并不是sql层面去查询而是Java层面
该方法被用来查询的频率不是很大 作为了解

1、mapper接口

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

2、mapper文件


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 users = session.selectList("getUserByRowBounds", null, rowBounds);

   for (User user: users){
       System.out.println(user);
  }
   session.close();
}

除此之外还有 mybatis的分页插件——官方文档pagehelper
实现更高效的查询工作。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/880503.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号