Java中mybatis的三種分頁方式
前言
分頁是我們在開發(fā)中繞不過去的一個坎!當你的數據量大了的時候,一次性將所有數據查出來不現實,所以我們一般都是分頁查詢的,減輕服務端的壓力,提升了速度和效率!也減輕了前端渲染的壓力!
注意:由于 java 允許的最大整數為 2147483647,所以 limit 能使用的最大整數也是 2147483647,一次性取出大量數據可能引起內存溢出,所以在大數據查詢場合慎重使用!
一、Limit分頁
語法:
limit?${startPos},${pageSize}在實際項目中我們一般會加上為空為null判斷,如下:
<if test="startPos!=null and pageSize!=null">
limit ${startPos},${pageSize}
</if>業(yè)務層代碼:
<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();
}執(zhí)行結果:

傳入0,10時:

總結:
- limit 0,10;
- 0 代表從第0條數據開始
- 10 代表查10條數據
- 等到第二頁的時候就是 limit 10,10;
以此類推!
這些內容其實就時MySQL中的內容,不作再詳細講解了。
二、RowBounds分頁(不推薦使用)
RowBounds幫我們省略了limit的內容,我們只需要在業(yè)務層關注分頁即可!無須再傳入指定數據!
但是,這個屬于邏輯分頁,即實際上sql查詢的是所有的數據,在業(yè)務層進行了分頁而已,比較占用內存,而且數據更新不及時,可能會有一定的滯后性!不推薦使用!
RowBounds對象有2個屬性,offset和limit。
- offset:起始行數
- limit:需要的數據行數
因此,取出來的數據就是:從第offset+1行開始,取limit行
業(yè)務層代碼:
@Test
public 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>
執(zhí)行查看結果:

三、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>業(yè)務層代碼:
@Test
public 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();
}執(zhí)行結果:

總結:
PageHelper還是很好用的,也是物理分頁!
實際上我們一般用第二種比較多:Mapper接口方式的調用
@Test
public 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條內容,默認查詢總數count PageHelper.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的三種分頁方式的文章就介紹到這了,更多相關Java mybatis分頁內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
SpringBoot項目打成War布署在Tomcat的詳細步驟
這篇文章主要介紹了SpringBoot項目打成War布署在Tomcat,本文分步驟結合圖文實例給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03
使用@ConfigurationProperties注解獲取為null的解決方法
在SpringBoot中,當想需要獲取到配置文件數據時,除了可以用 Spring 自帶的@Value注解外,SpringBoot還提供了一種更加方便的方式:@ConfigurationProperties,但我們在通過通過get方法去取值一直為null,本文介紹了使用@ConfigurationProperties注解獲取為null的解決方法2024-09-09
springSecurity自定義登錄接口和JWT認證過濾器的流程
這篇文章主要介紹了springSecurity自定義登陸接口和JWT認證過濾器的相關資料,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2024-12-12

