av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:91日期:2023-10-22 19:53:47

在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 多表分頁查詢內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 黄免费观看视频 | 久久久高清 | 久久久久久久久久久久一区二区 | 精品成人一区二区 | 日韩中文字幕在线视频 | 91在线免费视频 | 欧美一区二区视频 | 黄色av一区 | 成人免费在线播放视频 | 99精品免费 | 欧美激情国产精品 | 久久r久久 | 精品福利一区 | 一区二区三区在线观看视频 | 亚洲视频在线免费 | 亚洲一区久久久 | 97免费视频在线观看 | 日韩综合网 | 免费久久久 | 欧美一级精品片在线看 | 夜夜艹 | 国产精品777一区二区 | 蜜桃视频一区二区三区 | 九九热这里只有精品在线观看 | 亚洲 欧美 另类 综合 偷拍 | 亚洲一区在线日韩在线深爱 | 欧美另类视频 | 日韩在线视频一区 | 在线一区二区观看 | 久久精品一区 | 精品一区二区三区在线观看 | 日韩欧美一区二区三区免费观看 | 欧美一区二区另类 | 日本a级大片 | 久久久久国产一区二区 | 成人午夜在线视频 | 麻豆av一区二区三区久久 | 久久久久国产一区二区三区四区 | 精品视频在线观看 | 中文字幕在线第一页 | 亚洲第一中文字幕 |