一文搞懂Mybatis-plus的分頁查詢操作
1. 簡單說明
嗨,大家好!今天給大家分享的是Mybatis-plus 插件的分頁機制,說起分頁機制,相信我們程序員都不陌生,今天,我就給大家分享一下Mybatis-plus的分頁機制,供大家學(xué)習(xí)和Copy。
2. 介紹說明
如果你想看代碼,可以直接跳到代碼區(qū)域,這里只是一些簡單的說明,如果你想學(xué)習(xí),建議可以看看這一塊的任容。
本章節(jié)將介紹 BaseMapper 中的分頁查詢,BaseMapper 接口提供了如下幾個分頁查詢接口:
- selectPage:根據(jù) entity 條件,查詢?nèi)坑涗?/li>
- selectMapsPage:根據(jù) Wrapper 條件,查詢?nèi)坑涗?/li>
在使用上面兩個方法進行分頁查詢時,我們需要配置分頁插件。這是只是在介紹SpringBoot的使用。
注意:由于我們使用的 Spring Boot 項目,因此需要通過 @Configuration 和 @Bean 注解來添加配置
3. 完整配置類代碼
下邊就是完整的配置類,至于為什么比官網(wǎng)上的少一點,因為那個可以說會報錯,而且也不需要使用到它,以下就是完整配置類:
package com.hxstrive.mybatis_plus; import com.baomidou.mybatisplus.annotation.DbType; import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor; import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class MybatisPlusConfig { /** * 分頁插件。如果你不配置,分頁插件將不生效 */ @Bean public MybatisPlusInterceptor paginationInterceptor() { MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); // 指定數(shù)據(jù)庫方言為 MYSQL interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); return interceptor; } }
注意:如果你沒有配置分頁插件,則不會進行分頁。所以這個一定要配置。
4. 示例代碼
1.使用 QueryWrapper 和 Page 作為參數(shù)進行分頁,例如:
package com.hxstrive.mybatis_plus.select; import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.hxstrive.mybatis_plus.mapper.SimpleMapper; import com.hxstrive.mybatis_plus.model.UserBean; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; @RunWith(SpringRunner.class) @SpringBootTest class Select6Test { @Autowired private SimpleMapper simpleMapper; @Test void contextLoads() { QueryWrapper<UserBean> wrapper = new QueryWrapper<>(); wrapper.isNotNull("user_id"); // 創(chuàng)建分頁對象(1表示第一頁;4表示每頁大小為4) Page<UserBean> page = new Page<>(1, 4); Page<UserBean> result = simpleMapper.selectPage(page, wrapper); System.out.println("page == result: " + (page == result)); System.out.println("size: " + result.getSize()); System.out.println("total: " + result.getTotal()); for(UserBean userBean : result.getRecords()) { System.out.println(userBean); } } }
運行上面代碼,你會發(fā)現(xiàn) page 和selectPage 返回的 result1 相等,說明兩者是同一個對象。因此,可以忽略掉 selectPage 方法的返回結(jié)果,如下:
Page<UserBean> page = new Page<>(1, 4);
simpleMapper.selectPage(page, wrapper);
2.另外一個分頁方法,selectMapsPage 和上面的使用方法一樣,僅僅是返回類型不一樣。代碼如下:
package com.hxstrive.mybatis_plus.select; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.hxstrive.mybatis_plus.mapper.SimpleMapper; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; import java.util.Map; @RunWith(SpringRunner.class) @SpringBootTest class Select7Test { @Autowired private SimpleMapper simpleMapper; @Test void contextLoads() { // 返回的結(jié)果類型為 Map<String,Object> Page<Map<String,Object>> page = new Page<>(1, 4); simpleMapper.selectMapsPage(page, null); System.out.println("size: " + page.getSize()); System.out.println("total: " + page.getTotal()); System.out.println("pages: " + page.getPages()); for(Map<String,Object> map : page.getRecords()) { System.out.println(map); } } }
注意:這里我們平常會使用以下代碼獲取page里邊的存放的代碼。
page.getRecords():這是用來獲取我們分頁查出來的數(shù)據(jù)
5. 最后總結(jié)
這一小結(jié),我們主要是對mybatis-pluts 插件的分頁功能的使用,做了簡單介紹。下邊我們來梳理以下,使用插件步驟:
- 在我們項目的配置文件夾下,一定要添加MybatisPlusConfig
- 我們需要在這個配置類中添加paginationInterceptor()方法,進行分頁功能的配置,其實就是配置分頁功能的攔截器
- 使用方法,進來數(shù)據(jù)的分頁
- 使用方法,返回分頁的數(shù)據(jù)
以上就是一文搞懂Mybatis-plus的分頁查詢操作的詳細內(nèi)容,更多關(guān)于Mybatis-plus分頁查詢的資料請關(guān)注腳本之家其它相關(guān)文章!
- Mybatis-Plus 多表聯(lián)查分頁的實現(xiàn)代碼
- Mybatis-plus新版本分頁失效PaginationInterceptor過時的問題
- MyBatis-Plus 分頁查詢以及自定義sql分頁的實現(xiàn)
- mybatis-plus分頁傳入?yún)?shù)后sql where條件沒有l(wèi)imit分頁信息操作
- mybatis-plus分頁查詢的實現(xiàn)示例
- MyBatis-Plus分頁插件不生效的解決方法
- MyBatis-Plus實現(xiàn)2種分頁方法(QueryWrapper查詢分頁和SQL查詢分頁)
- MyBatis-Plus分頁時排序的實現(xiàn)方法
- 解決mybatis-plus3.4.1分頁插件PaginationInterceptor和防止全表更新與刪除插件SqlExplainInterceptor過時失效問題
- Mybatis-Plus中分頁插件PaginationInterceptor的使用
- MyBatis-Plus 分頁插件配置的兩種方式實現(xiàn)
相關(guān)文章
如何解決java.lang.IllegalStateException: Target host&n
文章描述了通過MocoRunner模擬接口,并使用properties文件和ResourceBundle讀取配置文件進行g(shù)et請求的過程,在執(zhí)行過程中遇到了目標主機為空的錯誤,通過檢查和修正url拼接問題解決了該錯誤2024-12-12Java LinkedList的實現(xiàn)原理圖文詳解
今天小編就為大家分享一篇關(guān)于Java LinkedList的實現(xiàn)原理圖文詳解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-01-01IDEA下SpringBoot指定環(huán)境、配置文件啟動操作過程
這篇文章主要介紹了IDEA下SpringBoot指定環(huán)境、配置文件啟動過程,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08