欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于Mybatis使用collection分頁問題

 更新時間:2021年11月23日 16:01:06   作者:FLY-DUCK  
項目中mybatis分頁的場景是非常高頻的,當(dāng)使用ResultMap并配置collection做分頁的時候,我們可能會遇到獲取當(dāng)前頁的數(shù)據(jù)少于每頁大小的數(shù)據(jù)問題。接下來通過本文給大家介紹Mybatis使用collection分頁問題,感興趣的朋友一起看看吧

項目中mybatis分頁的場景是非常高頻的,當(dāng)使用ResultMap并配置collection做分頁的時候,我們可能會遇到獲取當(dāng)前頁的數(shù)據(jù)少于每頁大小的數(shù)據(jù)問題。使用PagerHelper插件同樣會遇到該問題。

原因

引起該問題的原因是當(dāng)我們使用的是ResultMap集合的嵌套結(jié)果映射來處理通過join查詢的結(jié)果集,映射成Java實體類型的時候,會導(dǎo)致主數(shù)據(jù)被映射折疊后少于從數(shù)據(jù)庫獲取的數(shù)據(jù),從而導(dǎo)致獲取的映射數(shù)據(jù)少于每頁大小的數(shù)據(jù)。

方案

方案一

不使用集合的嵌套結(jié)果映射,使用集合的嵌套select查詢解決。使用該方案需要注意性能問題,會導(dǎo)致“N+1查詢問題”。

這種方式雖然很簡單,但在大型數(shù)據(jù)集或大型數(shù)據(jù)表上表現(xiàn)不佳。這個問題被稱為“N+1 查詢問題”。 概括地講,N+1 查詢問題是這樣子的:

你執(zhí)行了一個單獨的 SQL 語句來獲取結(jié)果的一個列表(就是“+1”)。對列表返回的每條記錄,你執(zhí)行一個 select 查詢語句來為每條記錄加載詳細信息(就是“N”)。

這個問題會導(dǎo)致成百上千的 SQL 語句被執(zhí)行。有時候,我們不希望產(chǎn)生這樣的后果。

好消息是,MyBatis 能夠?qū)@樣的查詢進行延遲加載,因此可以將大量語句同時運行的開銷分散開來。 然而,如果你加載記錄列表之后立刻就遍歷列表以獲取嵌套的數(shù)據(jù),就會觸發(fā)所有的延遲加載查詢,性能可能會變得很糟糕。

方案二

移除collection配置,在業(yè)務(wù)邏輯中進行處理。先將參與分頁的數(shù)據(jù)獲取出來,再根據(jù)需要在業(yè)務(wù)代碼中獲取分頁數(shù)據(jù)關(guān)聯(lián)的數(shù)據(jù)。博主更傾向于這種方案解決mybatis中collection分頁問題。

擴展

Mybatis中配置加載一對多關(guān)系的兩種方式:

1.集合的嵌套 Select 查詢

一共會產(chǎn)生兩個SQL語句,一個查詢主的數(shù)據(jù),另一個查詢關(guān)聯(lián)的數(shù)據(jù)。如下所示:

<resultMap id="blogResult" type="Blog">
  <collection property="posts" javaType="ArrayList" column="id" ofType="Post" select="selectPostsForBlog"/>
</resultMap>
 
<select id="selectBlog" resultMap="blogResult">
  SELECT * FROM BLOG WHERE ID = #{id}
</select>
 
<select id="selectPostsForBlog" resultType="Post">
  SELECT * FROM POST WHERE BLOG_ID = #{id}
</select>

2.集合的嵌套結(jié)果映射

只會產(chǎn)品一個SQL語句,主數(shù)據(jù)以及關(guān)聯(lián)數(shù)據(jù)通過別名的形式進行配置映射到各自的對象的屬性上。入戲所示:

<resultMap id="blogResult" type="Blog">
  <id property="id" column="blog_id" />
  <result property="title" column="blog_title"/>
  <collection property="posts" ofType="Post" resultMap="blogPostResult" columnPrefix="post_"/>
</resultMap>
 
<resultMap id="blogPostResult" type="Post">
  <id property="id" column="id"/>
  <result property="subject" column="subject"/>
  <result property="body" column="body"/>
</resultMap>

參考:

官方Mybatis高級結(jié)果映射ResultMap介紹與使用(包含collection使用)

PageHelper插件重要提示(分頁插件不支持嵌套結(jié)果映射)

mybatis resultMap之collection聚集兩種實現(xiàn)方式

到此這篇關(guān)于Mybatis使用collection分頁問題的文章就介紹到這了,更多相關(guān)Mybatis collection分頁內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Go Java算法之外觀數(shù)列實現(xiàn)方法示例詳解

    Go Java算法之外觀數(shù)列實現(xiàn)方法示例詳解

    這篇文章主要為大家介紹了Go Java算法外觀數(shù)列實現(xiàn)的方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • java 虛擬機深入了解

    java 虛擬機深入了解

    這篇文章主要介紹了java 虛擬機深入了解的相關(guān)資料,ava虛擬機有自己完善的硬體架構(gòu),如處理器、堆棧、寄存器等,還具有相應(yīng)的指令系統(tǒng),需要的朋友可以參考下
    2017-03-03
  • Spring Boot 2.0快速構(gòu)建服務(wù)組件全步驟

    Spring Boot 2.0快速構(gòu)建服務(wù)組件全步驟

    這篇文章主要給大家介紹了關(guān)于Spring Boot 2.0快速構(gòu)建服務(wù)組件的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用Spring Boot 2.0具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • SpringBoot中打印SQL語句的幾種方法實現(xiàn)

    SpringBoot中打印SQL語句的幾種方法實現(xiàn)

    本文主要介紹了SpringBoot中打印SQL語句的幾種方法實現(xiàn),,通過打印SQL語句可以幫助開發(fā)人員快速了解數(shù)據(jù)庫的操作情況,進而進行性能分析和調(diào)試,感興趣的可以了解一下
    2023-11-11
  • Java 如何解析key為動態(tài)的json操作

    Java 如何解析key為動態(tài)的json操作

    這篇文章主要介紹了Java 如何解析key為動態(tài)的json操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • java調(diào)用shell命令并獲取執(zhí)行結(jié)果的示例

    java調(diào)用shell命令并獲取執(zhí)行結(jié)果的示例

    今天小編就為大家分享一篇java調(diào)用shell命令并獲取執(zhí)行結(jié)果的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動刷新配置的教程

    Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動刷新配置的教程

    這篇文章主要介紹了Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動刷新配置,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • SpringBoot集成Redis的實現(xiàn)示例

    SpringBoot集成Redis的實現(xiàn)示例

    這篇文章主要介紹了SpringBoot集成Redis的實現(xiàn)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • 基于springboot微信公眾號開發(fā)(微信自動回復(fù))

    基于springboot微信公眾號開發(fā)(微信自動回復(fù))

    這篇文章主要介紹了基于springboot微信公眾號開發(fā)(微信自動回復(fù)),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • Spring boot自定義http反饋狀態(tài)碼詳解

    Spring boot自定義http反饋狀態(tài)碼詳解

    這篇文章主要給大家介紹了Spring boot自定義http反饋狀態(tài)碼的相關(guān)資料,文中介紹的非常詳細,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。
    2017-06-06

最新評論