亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

一文搞懂Mybatis-plus的分頁(yè)查詢操作

 更新時(shí)間:2022年06月15日 10:12:51   作者:知識(shí)的搬運(yùn)工旺仔  
說(shuō)起分頁(yè)機(jī)制,相信我們程序員都不陌生,今天,我就給大家分享一下Mybatis-plus的分頁(yè)機(jī)制,供大家學(xué)習(xí)和Copy,感興趣的可以了解一下

1. 簡(jiǎn)單說(shuō)明

嗨,大家好!今天給大家分享的是Mybatis-plus 插件的分頁(yè)機(jī)制,說(shuō)起分頁(yè)機(jī)制,相信我們程序員都不陌生,今天,我就給大家分享一下Mybatis-plus的分頁(yè)機(jī)制,供大家學(xué)習(xí)和Copy。

2. 介紹說(shuō)明

如果你想看代碼,可以直接跳到代碼區(qū)域,這里只是一些簡(jiǎn)單的說(shuō)明,如果你想學(xué)習(xí),建議可以看看這一塊的任容。

本章節(jié)將介紹 BaseMapper 中的分頁(yè)查詢,BaseMapper 接口提供了如下幾個(gè)分頁(yè)查詢接口:

  • selectPage:根據(jù) entity 條件,查詢?nèi)坑涗?/li>
  • selectMapsPage:根據(jù) Wrapper 條件,查詢?nèi)坑涗?/li>

在使用上面兩個(gè)方法進(jìn)行分頁(yè)查詢時(shí),我們需要配置分頁(yè)插件。這是只是在介紹SpringBoot的使用。

注意:由于我們使用的 Spring Boot 項(xiàng)目,因此需要通過(guò) @Configuration 和 @Bean 注解來(lái)添加配置

3. 完整配置類代碼

下邊就是完整的配置類,至于為什么比官網(wǎng)上的少一點(diǎn),因?yàn)槟莻€(gè)可以說(shuō)會(huì)報(bào)錯(cuò),而且也不需要使用到它,以下就是完整配置類:

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 {
 
    /**
     * 分頁(yè)插件。如果你不配置,分頁(yè)插件將不生效
     */
    @Bean
    public MybatisPlusInterceptor paginationInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        // 指定數(shù)據(jù)庫(kù)方言為 MYSQL
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }
 
}

注意:如果你沒(méi)有配置分頁(yè)插件,則不會(huì)進(jìn)行分頁(yè)。所以這個(gè)一定要配置。

4. 示例代碼

1.使用 QueryWrapper 和 Page 作為參數(shù)進(jìn)行分頁(yè),例如:

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)建分頁(yè)對(duì)象(1表示第一頁(yè);4表示每頁(yè)大小為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);
       }
   }

}

運(yùn)行上面代碼,你會(huì)發(fā)現(xiàn) page 和selectPage 返回的 result1 相等,說(shuō)明兩者是同一個(gè)對(duì)象。因此,可以忽略掉 selectPage 方法的返回結(jié)果,如下:

Page<UserBean> page = new Page<>(1, 4);
simpleMapper.selectPage(page, wrapper);

2.另外一個(gè)分頁(yè)方法,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);
        }
    }
 
}

注意:這里我們平常會(huì)使用以下代碼獲取page里邊的存放的代碼。

page.getRecords():這是用來(lái)獲取我們分頁(yè)查出來(lái)的數(shù)據(jù)

5. 最后總結(jié)

這一小結(jié),我們主要是對(duì)mybatis-pluts 插件的分頁(yè)功能的使用,做了簡(jiǎn)單介紹。下邊我們來(lái)梳理以下,使用插件步驟:

  • 在我們項(xiàng)目的配置文件夾下,一定要添加MybatisPlusConfig
  • 我們需要在這個(gè)配置類中添加paginationInterceptor()方法,進(jìn)行分頁(yè)功能的配置,其實(shí)就是配置分頁(yè)功能的攔截器
  • 使用方法,進(jìn)來(lái)數(shù)據(jù)的分頁(yè)
  • 使用方法,返回分頁(yè)的數(shù)據(jù)

以上就是一文搞懂Mybatis-plus的分頁(yè)查詢操作的詳細(xì)內(nèi)容,更多關(guān)于Mybatis-plus分頁(yè)查詢的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 淺談標(biāo)簽和JLabel類構(gòu)造方法

    淺談標(biāo)簽和JLabel類構(gòu)造方法

    這篇文章主要介紹了標(biāo)簽和JLabel類構(gòu)造方法,具有一定參考價(jià)值,需要的朋友可以參考下。
    2017-09-09
  • 如何解決java.lang.IllegalStateException: Target host is null的問(wèn)題

    如何解決java.lang.IllegalStateException: Target host&n

    文章描述了通過(guò)MocoRunner模擬接口,并使用properties文件和ResourceBundle讀取配置文件進(jìn)行g(shù)et請(qǐng)求的過(guò)程,在執(zhí)行過(guò)程中遇到了目標(biāo)主機(jī)為空的錯(cuò)誤,通過(guò)檢查和修正url拼接問(wèn)題解決了該錯(cuò)誤
    2024-12-12
  • Java設(shè)計(jì)模式之java外觀模式詳解

    Java設(shè)計(jì)模式之java外觀模式詳解

    這篇文章主要介紹了Java設(shè)計(jì)模式之外觀模式(Facade模式)介紹,外觀模式(Facade)的定義:為子系統(tǒng)中的一組接口提供一個(gè)一致的界面,需要的朋友可以參考下
    2021-09-09
  • Spring中緩存注解@Cache的使用詳解

    Spring中緩存注解@Cache的使用詳解

    這篇文章主要介紹了Spring中緩存注解@Cache的使用詳解,使用注解對(duì)數(shù)據(jù)進(jìn)行緩存功能的框架,只需要簡(jiǎn)單地加一個(gè)注解,就能實(shí)現(xiàn)緩存功能,大大簡(jiǎn)化我們?cè)跇I(yè)務(wù)中操作緩存的代碼,需要的朋友可以參考下
    2023-07-07
  • Java仿淘寶首頁(yè)分類列表功能的示例代碼

    Java仿淘寶首頁(yè)分類列表功能的示例代碼

    這篇文章主要介紹了仿淘寶分類管理功能的示例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,也給大家做個(gè)參考
    2018-05-05
  • Java LinkedList的實(shí)現(xiàn)原理圖文詳解

    Java LinkedList的實(shí)現(xiàn)原理圖文詳解

    今天小編就為大家分享一篇關(guān)于Java LinkedList的實(shí)現(xiàn)原理圖文詳解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-01-01
  • Java實(shí)用工具庫(kù)commons-lang3的使用

    Java實(shí)用工具庫(kù)commons-lang3的使用

    Apache?Commons?Lang?3是一個(gè)流行的Java實(shí)用工具庫(kù),提供了對(duì)java.lang包的擴(kuò)展,包括字符串操作、正則表達(dá)式處理、數(shù)字操作、日期和時(shí)間操作、隨機(jī)字符串生成和對(duì)象操作等功能
    2025-03-03
  • Java由淺入深講解繼承下

    Java由淺入深講解繼承下

    繼承就是可以直接使用前輩的屬性和方法。自然界如果沒(méi)有繼承,那一切都是處于混沌狀態(tài)。多態(tài)是同一個(gè)行為具有多個(gè)不同表現(xiàn)形式或形態(tài)的能力。多態(tài)就是同一個(gè)接口,使用不同的實(shí)例而執(zhí)行不同操作
    2022-04-04
  • 淺談log4j的rootLogger及其他坑爹的地方

    淺談log4j的rootLogger及其他坑爹的地方

    這篇文章主要介紹了log4j的rootLogger及其他坑爹的地方,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • IDEA下SpringBoot指定環(huán)境、配置文件啟動(dòng)操作過(guò)程

    IDEA下SpringBoot指定環(huán)境、配置文件啟動(dòng)操作過(guò)程

    這篇文章主要介紹了IDEA下SpringBoot指定環(huán)境、配置文件啟動(dòng)過(guò)程,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-08-08

最新評(píng)論