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

MyBatis Plus 實(shí)現(xiàn)多表分頁(yè)查詢功能的示例代碼

 更新時(shí)間:2020年08月31日 10:19:24   作者:騎驢的小牧童  
這篇文章主要介紹了MyBatis Plus 實(shí)現(xiàn)多表分頁(yè)查詢功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

在Mybatis Plus 中,雖然IService 接口幫我們定義了很多常用的方法,但這些都是 T 對(duì)象有用,如果涉及到 多表的查詢,還是需要自定義Vo 對(duì)象和自己編寫sql 語(yǔ)句,Mybatis Plus提供了一個(gè)Page 對(duì)象,查詢是需要設(shè)置其中的 size 字段 和 current 字段的值

一、分頁(yè)配置

可以直接使用selectPage這樣的分頁(yè),但返回的數(shù)據(jù)確實(shí)是分頁(yè)后的數(shù)據(jù),但在控制臺(tái)打印的SQL語(yǔ)句其實(shí)并沒有真正的物理分頁(yè),而是通過緩存來獲得全部數(shù)據(jù)中再進(jìn)行的分頁(yè),這樣對(duì)于大數(shù)據(jù)量操作時(shí)是不可取的,那么接下來就敘述一下,真正實(shí)現(xiàn)物理分頁(yè)的方法。
官方在分頁(yè)插件上如是描述:自定義查詢語(yǔ)句分頁(yè)(自己寫sql/mapper),也就是針對(duì)自己在Mapper中寫的方法,但經(jīng)過測(cè)試,如果不配置分頁(yè)插件,其默認(rèn)采用的分頁(yè)為RowBounds的分頁(yè)即邏輯分頁(yè),也就是先把數(shù)據(jù)記錄全部查詢出來,然在再根據(jù)offset和limit截?cái)嘤涗浄祷兀〝?shù)據(jù)量大的時(shí)候會(huì)造成內(nèi)存溢出),故而不可取,而通過分頁(yè)插件的配置即可達(dá)到物理分頁(yè)效果。

新建一個(gè)MybatisPlusConfig配置類文件,代碼如下所示:

import com.baomidou.mybatisplus.plugins.PaginationInterceptor;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
 
@Configuration
@EnableTransactionManagement(proxyTargetClass = true)
public class MybatisPlusConfig {
 
  /**
   * mybatis-plus分頁(yè)插件<br>
   */
  @Bean
  public PaginationInterceptor paginationInterceptor() {
    PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
    return paginationInterceptor;
  }
}

二、使用分頁(yè)進(jìn)行單表的查詢

對(duì)于單表的分頁(yè)查詢,ServiceImpl 類已經(jīng)為我們提供了對(duì)應(yīng)的方法 selectPage(),并將結(jié)果封裝到Page 對(duì)象中:

在這里插入圖片描述

在項(xiàng)目開發(fā)當(dāng)中,都會(huì)將分頁(yè)的一些參數(shù)封裝成一個(gè)類 PageReq(不要在意這個(gè)Req 為什么不是全大寫)->import java.io.Serializable;

public class PageReq implements Serializable {

  /**
   * 每頁(yè)顯示大小
   */
  private long size;

  /**
   * 當(dāng)前頁(yè)碼
   */
  private long current;

  /**
   * 最大頁(yè)數(shù)
   */
  private long maxCurrent;

  /**
   * 數(shù)據(jù)總條數(shù)
   */
  private long total;

  public long getSize() {
    return size;
  }

  public void setSize(long size) {
    this.size = size;
  }

  public long getCurrent() {
    return current;
  }

  public void setCurrent(long current) {
    this.current = current;
  }

  public long getMaxCurrent() {
    return maxCurrent;
  }

  public void setMaxCurrent(long maxCurrent) {
    this.maxCurrent = maxCurrent;
  }

  public long getTotal() {
    return total;
  }

  public void setTotal(long total) {
    if(size != 0){
      if(total % size != 0){
        maxCurrent = total / size + 1;
      }else {
        maxCurrent = total / size;
      }
    }
  }

  public PageReq() {

  }

  public PageReq(long size, long current, long total) {
    this.size = size;
    this.current = current;
    this.total = total;
    setTotal(total);
  }
}

功能編寫:

在這里插入圖片描述
在這里插入圖片描述

執(zhí)行完之后,會(huì)將查詢的接口封裝到我們 Page的 對(duì)象中:

在這里插入圖片描述

三、多表關(guān)聯(lián)分頁(yè)查詢

對(duì)于多表關(guān)聯(lián)的查詢時(shí),還是需要編寫 VO 類和 手動(dòng)的在Mapper.xml 中編寫sql,雖然是可以不用創(chuàng)建VO,用Map 的方式接受返回的結(jié)果,但這樣只會(huì)更麻煩,甚至VO 是很有可能在其他地方使用的
先準(zhǔn)備個(gè)VO類:

在這里插入圖片描述

編寫Mapper接口,添加一個(gè)分頁(yè)查詢的方法
package com.eiot.e_view.mapper;

import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.eiot.e_view.model.req.RoomPageReq;
import com.eiot.e_view.model.vo.RoomVO;
import org.apache.ibatis.annotations.Param;

import java.util.List;

public interface RoomMapper extends BaseMapper<Room> {

  List<RoomVO> getRoomPageList(Page page, @Param("roomPageReq")RoomPageReq roomPageReq);
}

編寫sql,和我們使用Mybatis 沒有區(qū)別:

在這里插入圖片描述
在這里插入圖片描述

編寫Server :

在這里插入圖片描述

執(zhí)行結(jié)果:

在這里插入圖片描述

總結(jié)

到此這篇關(guān)于MyBatis Plus 實(shí)現(xiàn)多表分頁(yè)查詢功能的示例代碼的文章就介紹到這了,更多相關(guān)MyBatis Plus 多表分頁(yè)查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringMVC空指針異常NullPointerException解決及原理解析

    SpringMVC空指針異常NullPointerException解決及原理解析

    這篇文章主要介紹了SpringMVC空指針異常NullPointerException解決及原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • SpringMVC使用hibernate-validator進(jìn)行參數(shù)校驗(yàn)最佳實(shí)踐記錄

    SpringMVC使用hibernate-validator進(jìn)行參數(shù)校驗(yàn)最佳實(shí)踐記錄

    這篇文章主要介紹了SpringMVC使用hibernate-validator進(jìn)行參數(shù)校驗(yàn)最佳實(shí)踐,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-05-05
  • Springboot獲取jar包中resources資源目錄下的文件

    Springboot獲取jar包中resources資源目錄下的文件

    今天在項(xiàng)目中遇到一個(gè)業(yè)務(wù)場(chǎng)景,需要用到resources資源目錄下的文件,本文主要介紹了Springboot獲取jar包中resources資源目錄下的文件,感興趣的可以了解一下
    2023-12-12
  • SpringBoot下使用定時(shí)任務(wù)的方式全揭秘(6種)

    SpringBoot下使用定時(shí)任務(wù)的方式全揭秘(6種)

    這篇文章主要介紹了SpringBoot下使用定時(shí)任務(wù)的方式全揭秘(6種),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-02-02
  • 快速上手Java中的Properties集合類

    快速上手Java中的Properties集合類

    java.util.Properties集合繼承于Hashtable,來表示一個(gè)持久的屬性集,他使用鍵值結(jié)構(gòu)存儲(chǔ)數(shù)據(jù),每個(gè)鍵及其對(duì)應(yīng)的值都是一個(gè)字符串,該類被許多java類使用,下面這篇文章主要給大家介紹了關(guān)于如何快速上手Java中Properties集合類的相關(guān)資料,需要的朋友可以參考下
    2023-02-02
  • JAVA實(shí)現(xiàn)對(duì)阿里云DNS的解析管理

    JAVA實(shí)現(xiàn)對(duì)阿里云DNS的解析管理

    本文主要介紹了JAVA實(shí)現(xiàn)對(duì)阿里云DNS的解析管理,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • SpringBoot定制三種錯(cuò)誤頁(yè)面及錯(cuò)誤數(shù)據(jù)方法示例

    SpringBoot定制三種錯(cuò)誤頁(yè)面及錯(cuò)誤數(shù)據(jù)方法示例

    Spring Boot提供的默認(rèn)異常處理機(jī)制通常并不一定適合我們實(shí)際的業(yè)務(wù)場(chǎng)景,因此,我們通常會(huì)根據(jù)自身的需要對(duì)Spring Boot全局異常進(jìn)行統(tǒng)一定制,例如定制錯(cuò)誤頁(yè)面,定制錯(cuò)誤數(shù)據(jù)等。本文主要介紹了SpringBoot三種自定義錯(cuò)誤頁(yè)面的實(shí)現(xiàn),快來學(xué)習(xí)吧
    2021-12-12
  • 淺談Java中的n種隨機(jī)數(shù)產(chǎn)生辦法

    淺談Java中的n種隨機(jī)數(shù)產(chǎn)生辦法

    眾所周知,隨機(jī)數(shù)是任何一種編程語(yǔ)言最基本的特征之一。而生成隨機(jī)數(shù)的基本方式也是相同的:產(chǎn)生一個(gè)0到1之間的隨機(jī)數(shù)??此坪?jiǎn)單,但有時(shí)我們也會(huì)忽略了一些有趣的功能。
    2015-09-09
  • Spring為singleton?bean注入prototype?bean

    Spring為singleton?bean注入prototype?bean

    這篇文章主要介紹了Spring為singleton?bean注入prototype?bean,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-07-07
  • 使用Mybatis遇到的坑之Integer類型參數(shù)的解讀

    使用Mybatis遇到的坑之Integer類型參數(shù)的解讀

    這篇文章主要介紹了使用Mybatis遇到的坑之Integer類型參數(shù)的解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03

最新評(píng)論