一文搞懂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)文章
spring boot與redis 實現(xiàn)session共享教程
這篇文章主要介紹了spring boot與redis 實現(xiàn)session共享教程,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-04-04
SpringBoot項目中Controller接收兩個實體的實現(xiàn)方法
本文主要介紹了SpringBoot項目中Controller接收兩個實體的實現(xiàn)方法,主要介紹了兩種方法,具有一定的參考價值,感興趣的可以了解一下2023-08-08
java 使用idea將工程打成jar并創(chuàng)建成exe文件類型執(zhí)行的方法詳解
這篇文章主要介紹了java 使用idea將工程打成jar并創(chuàng)建成exe文件類型執(zhí)行,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2020-09-09
Mybatis-Plus中的MetaObjectHandler組件的使用
MetaObjectHandler是Mybatis-Plus中一個實用組件,專門用于自動處理實體對象中的特定字段,如創(chuàng)建時間、更新時間、創(chuàng)建人和修改人等,該接口允許開發(fā)者在不修改業(yè)務(wù)代碼的情況下,實現(xiàn)自動填充功能,極大地簡化了代碼的復(fù)雜性,感興趣的可以了解一下2024-10-10
Linux環(huán)境卸載Centos7自帶的OpenJDK和安裝JDK1.8圖文教程
CentOS系統(tǒng)是開發(fā)者常用的Linux操作系統(tǒng),安裝它時會默認安裝自帶的舊版本的OpenJDK,但在開發(fā)者平時開發(fā)Java項目時還是需要完整的JDK,這篇文章主要給大家介紹了關(guān)于Linux環(huán)境卸載Centos7自帶的OpenJDK和安裝JDK1.8的相關(guān)資料,需要的朋友可以參考下2024-07-07

