您好,欢迎访问一九零五行业门户网

Java中MyBatis的分页实现方式有哪些?

前言分页是我们在开发中绕不过去的一个坎!当你的数据量大了的时候,一次性将所有数据查出来不现实,所以我们一般都是分页查询的,减轻服务端的压力,提升了速度和效率!也减轻了前端渲染的压力!
注意:由于 java 允许的最大整数为 2147483647,所以 limit 能使用的最大整数也是 2147483647,一次性取出大量数据可能引起内存溢出,所以在大数据查询场合慎重使用!
一、limit分页语法:
limit ${startpos},${pagesize}
在实际项目中我们一般会加上为空为null判断,如下:
<if test="startpos!=null and pagesize!=null"> limit ${startpos},${pagesize}</if>
业务层代码:
<select id="getuserinfo1" parametertype="map" resulttype="dayu"> select * from user <if test="startpos!=null and pagesize!=null"> limit ${startpos},${pagesize} </if></select>
list<user> getuserinfo1(map<string,object> map);
@test public void selectuser() { sqlsession session = mybatisutils.getsession(); usermapper mapper = session.getmapper(usermapper.class); //这里塞值 map<string,object> parms = new hashmap<>(); parms.put("startpos","0"); parms.put("pagesize","5"); list<user> users = mapper.getuserinfo1(parms); for (user map: users){ system.out.println(map); } session.close();}
执行结果:
传入0,10时:
总结:
limit 0,10;
0 代表从第0条数据开始
10 代表查10条数据
等到第二页的时候就是 limit 10,10;
二、rowbounds分页(不推荐使用)rowbounds帮我们省略了limit的内容,我们只需要在业务层关注分页即可!无须再传入指定数据!
但是,这个属于逻辑分页,即实际上sql查询的是所有的数据,在业务层进行了分页而已,比较占用内存,而且数据更新不及时,可能会有一定的滞后性!不推荐使用!
rowbounds对象有2个属性,offset和limit。
offset:起始行数
limit:需要的数据行数
因此,取出来的数据就是:从第offset+1行开始,取limit行
业务层代码:
@testpublic void selectuserrowbounds() { sqlsession session = mybatisutils.getsession(); usermapper mapper = session.getmapper(usermapper.class); // list<user> users = session.selectlist("com.dy.mapper.usermapper.getuserinforowbounds",null,new rowbounds(0, 5)); list<user> users = mapper.getuserinforowbounds(new rowbounds(0,5)); for (user map: users){ system.out.println(map); } session.close();}
list<user> getuserinforowbounds(rowbounds rowbounds);
<select id="getuserinforowbounds" resulttype="dayu"> select * from user</select>
执行查看结果:
三、mybatis_pagehelper分页插件引入jar包:
<dependency> <groupid>com.github.pagehelper</groupid> <artifactid>pagehelper</artifactid> <version>5.1.7</version></dependency>
配置mybatis核心配置文件:
<plugins> <plugin interceptor="com.github.pagehelper.pageinterceptor" /></plugins>
业务层代码:
@testpublic void selectuserpagehelper() { sqlsession session = mybatisutils.getsession(); usermapper mapper = session.getmapper(usermapper.class); //第二种,mapper接口方式的调用,推荐这种使用方式。 pagehelper.startpage(1, 3); list<user> list = mapper.getuserinfo(); //用pageinfo将包装起来 pageinfo page = new pageinfo(list); for (user map: list){ system.out.println(map); } system.out.println("page:---"+page); session.close();}

执行结果:
总结:
pagehelper还是很好用的,也是物理分页!
实际上我们一般用第二种比较多:mapper接口方式的调用
@testpublic void selectuserpagehelper() { sqlsession session = mybatisutils.getsession(); usermapper mapper = session.getmapper(usermapper.class); //第二种,mapper接口方式的调用,推荐这种使用方式。 pagehelper.startpage(1, 3); list<user> list = mapper.getuserinfo(); //用pageinfo将包装起来 pageinfo page = new pageinfo(list); for (user map: list){ system.out.println(map); } system.out.println("page:---"+page); session.close();}

拓展:
//获取第1页,10条内容,默认查询总数countpagehelper.startpage(1, 10);list<user> list = usermapper.selectall();//用pageinfo对结果进行包装pageinfo page = new pageinfo(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的分页实现方式有哪些?的详细内容。
其它类似信息

推荐信息