一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - MyBatis Plus 實現多表分頁查詢功能的示例代碼

MyBatis Plus 實現多表分頁查詢功能的示例代碼

2020-09-01 00:26騎驢的小牧童 Java教程

這篇文章主要介紹了MyBatis Plus 實現多表分頁查詢功能,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

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

一、分頁配置

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

新建一個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分頁插件<br>
   */
  @Bean
  public PaginationInterceptor paginationInterceptor() {
    PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
    return paginationInterceptor;
  }
}

二、使用分頁進行單表的查詢

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

MyBatis Plus 實現多表分頁查詢功能的示例代碼

在項目開發當中,都會將分頁的一些參數封裝成一個類 PageReq(不要在意這個Req 為什么不是全大寫)->import java.io.Serializable;

public class PageReq implements Serializable {

  /**
   * 每頁顯示大小
   */
  private long size;

  /**
   * 當前頁碼
   */
  private long current;

  /**
   * 最大頁數
   */
  private long maxCurrent;

  /**
   * 數據總條數
   */
  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);
  }
}

功能編寫:

MyBatis Plus 實現多表分頁查詢功能的示例代碼
MyBatis Plus 實現多表分頁查詢功能的示例代碼

執行完之后,會將查詢的接口封裝到我們 Page的 對象中:

MyBatis Plus 實現多表分頁查詢功能的示例代碼

三、多表關聯分頁查詢

對于多表關聯的查詢時,還是需要編寫 VO 類和 手動的在Mapper.xml 中編寫sql,雖然是可以不用創建VO,用Map 的方式接受返回的結果,但這樣只會更麻煩,甚至VO 是很有可能在其他地方使用的
先準備個VO類:

MyBatis Plus 實現多表分頁查詢功能的示例代碼

編寫Mapper接口,添加一個分頁查詢的方法
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 沒有區別:

MyBatis Plus 實現多表分頁查詢功能的示例代碼
MyBatis Plus 實現多表分頁查詢功能的示例代碼

編寫Server :

MyBatis Plus 實現多表分頁查詢功能的示例代碼

執行結果:

MyBatis Plus 實現多表分頁查詢功能的示例代碼

總結

到此這篇關于MyBatis Plus 實現多表分頁查詢功能的示例代碼的文章就介紹到這了,更多相關MyBatis Plus 多表分頁查詢內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/womenyiqilalala/article/details/95073892

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 色欲麻将 | 国产欧美日韩一区二区三区在线 | 免费视频完整版在线观看网站 | 二区三区视频 | 视频一区二区 村上凉子 | 免费在线观看成年人视频 | 亚洲AV国产国产久青草 | 国产精品乱码高清在线观看 | 人与动人物aaaa | 国产精品日韩欧美一区二区三区 | 天天做日日爱 | 99久女女精品视频在线观看 | 国产成人免费高清激情明星 | 成人人免费夜夜视频观看 | 天堂资源wwww在线看 | 欧美黑人一级 | 欧美日韩视频在线一区二区 | 嘉嘉的丝袜美腿白丝 | 欧美肥胖bb| 欧美在线一级片 | 国产精品久久久久不卡绿巨人 | 免费lulu网站 | 日韩精品久久不卡中文字幕 | 小SAO货边洗澡边CAO你动漫 | 亚洲国产一区二区a毛片 | 91视频完整版 | 国产区香蕉精品系列在线观看不卡 | 禁漫H天堂免费A漫 | free性丰满hd性欧美厨房 | 四虎4hu永久免费国产精品 | 日韩成人精品 | 99久久这里只有精品 | 男人操女人免费视频 | 特级淫片欧美高清视频蜜桃 | 精品精品国产yyy5857香蕉 | xxoo好深好爽动态 | 外国黄色软件 | 成人软件18免费 | 手机在线免费观看日本推理片 | 日本午夜影院 | 日本一道本中文字幕 |