Java中mybatis的分页方式有哪些(java,mybatis,开发技术)

时间:2024-05-09 10:58:14 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

当你的数据量大了的时候,一次性将所有数据查出来不现实,所以我们一般都是分页查询的,减轻服务端的压力,提升了速度和效率!也减轻了前端渲染的压力!

注意:由于 java 允许的最大整数为 2147483647,所以 limit 能使用的最大整数也是 2147483647,一次性取出大量数据可能引起内存溢出,所以在大数据查询场合慎重使用!

一、Limit分页

语法:

limit${startPos},${pageSize}

在实际项目中我们一般会加上为空为null判断,如下:

<iftest="startPos!=nullandpageSize!=null">
limit${startPos},${pageSize}
</if>

业务层代码:

<selectid="getUserInfo1"parameterType="map"resultType="dayu">
selectfromuser
<iftest="startPos!=nullandpageSize!=null">
limit${startPos},${pageSize}
</if>
</select>
List<User>getUserInfo1(Map<String,Object>map);
@Test
publicvoidselectUser(){
SqlSessionsession=MybatisUtils.getSession();
UserMappermapper=session.getMapper(UserMapper.class);
//这里塞值
Map<String,Object>parms=newHashMap<>();
parms.put("startPos","0");
parms.put("pageSize","5");
List<User>users=mapper.getUserInfo1(parms);
for(Usermap:users){
System.out.println(map);
}
session.close();
}

执行结果:

Java中mybatis的分页方式有哪些

传入0,10时:

Java中mybatis的分页方式有哪些

总结:

  • limit 0,10;

  • 0 代表从第0条数据开始

  • 10 代表查10条数据

  • 等到第二页的时候就是 limit 10,10;

二、RowBounds分页(不推荐使用)

RowBounds帮我们省略了limit的内容,我们只需要在业务层关注分页即可!无须再传入指定数据!

但是,这个属于逻辑分页,即实际上sql查询的是所有的数据,在业务层进行了分页而已,比较占用内存,而且数据更新不及时,可能会有一定的滞后性!不推荐使用!

RowBounds对象有2个属性,offset和limit。

  • offset:起始行数

  • limit:需要的数据行数

因此,取出来的数据就是:从第offset+1行开始,取limit行

业务层代码:

@Test
publicvoidselectUserRowBounds(){
SqlSessionsession=MybatisUtils.getSession();
UserMappermapper=session.getMapper(UserMapper.class);
//List<User>users=session.selectList("com.dy.mapper.UserMapper.getUserInfoRowBounds",null,newRowBounds(0,5));
List<User>users=mapper.getUserInfoRowBounds(newRowBounds(0,5));
for(Usermap:users){
System.out.println(map);
}
session.close();
}
List<User>getUserInfoRowBounds(RowBoundsrowBounds);
<selectid="getUserInfoRowBounds"resultType="dayu">
select
fromuser
</select>

执行查看结果:

Java中mybatis的分页方式有哪些

三、Mybatis_PageHelper分页插件

引入jar包:

<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.1.7</version>
</dependency>

配置MyBatis核心配置文件:

<plugins>
<plugininterceptor="com.github.pagehelper.PageInterceptor"/>
</plugins>

业务层代码:

@Test
publicvoidselectUserPageHelper(){
SqlSessionsession=MybatisUtils.getSession();
UserMappermapper=session.getMapper(UserMapper.class);
//第二种,Mapper接口方式的调用,推荐这种使用方式。
PageHelper.startPage(1,3);
List<User>list=mapper.getUserInfo();
//用PageInfo将包装起来
PageInfopage=newPageInfo(list);
for(Usermap:list){
System.out.println(map);
}
System.out.println("page:---"+page);
session.close();
}

执行结果:

Java中mybatis的分页方式有哪些

总结:

PageHelper还是很好用的,也是物理分页!

实际上我们一般用第二种比较多:Mapper接口方式的调用

@Test
publicvoidselectUserPageHelper(){
SqlSessionsession=MybatisUtils.getSession();
UserMappermapper=session.getMapper(UserMapper.class);
//第二种,Mapper接口方式的调用,推荐这种使用方式。
PageHelper.startPage(1,3);
List<User>list=mapper.getUserInfo();
//用PageInfo将包装起来
PageInfopage=newPageInfo(list);
for(Usermap:list){
System.out.println(map);
}
System.out.println("page:---"+page);
session.close();
}

拓展:

//获取第1页,10条内容,默认查询总数count
PageHelper.startPage(1,10);
List<User>list=userMapper.selectAll();
//用PageInfo对结果进行包装
PageInfopage=newPageInfo(list);
//测试PageInfo全部属性
//PageInfo包含了非常全面的分页属性
assertEquals(1,page.getPageNum());
assertEquals(10,page.getPageSize());
assertEquals(1,page.getStartRow());
assertEquals(10,page.getEndRow());
assertEquals(183,page.getTotal());
assertEquals(19,page.getPages());
assertEquals(1,page.getFirstPage());
assertEquals(8,page.getLastPage());
assertEquals(true,page.isFirstPage());
assertEquals(false,page.isLastPage());
assertEquals(false,page.isHasPreviousPage());
assertEquals(true,page.isHasNextPage());

关于“Java中mybatis的分页方式有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。

本文:Java中mybatis的分页方式有哪些的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:java开源好用的简繁转换类库实例分析下一篇:

7 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18