關(guān)于Mybatis使用collection分頁(yè)問(wèn)題
項(xiàng)目中mybatis分頁(yè)的場(chǎng)景是非常高頻的,當(dāng)使用ResultMap并配置collection做分頁(yè)的時(shí)候,我們可能會(huì)遇到獲取當(dāng)前頁(yè)的數(shù)據(jù)少于每頁(yè)大小的數(shù)據(jù)問(wèn)題。使用PagerHelper插件同樣會(huì)遇到該問(wèn)題。
原因
引起該問(wèn)題的原因是當(dāng)我們使用的是ResultMap集合的嵌套結(jié)果映射來(lái)處理通過(guò)join查詢(xún)的結(jié)果集,映射成Java實(shí)體類(lèi)型的時(shí)候,會(huì)導(dǎo)致主數(shù)據(jù)被映射折疊后少于從數(shù)據(jù)庫(kù)獲取的數(shù)據(jù),從而導(dǎo)致獲取的映射數(shù)據(jù)少于每頁(yè)大小的數(shù)據(jù)。
方案
方案一
不使用集合的嵌套結(jié)果映射,使用集合的嵌套select查詢(xún)解決。使用該方案需要注意性能問(wèn)題,會(huì)導(dǎo)致“N+1查詢(xún)問(wèn)題”。
這種方式雖然很簡(jiǎn)單,但在大型數(shù)據(jù)集或大型數(shù)據(jù)表上表現(xiàn)不佳。這個(gè)問(wèn)題被稱(chēng)為“N+1 查詢(xún)問(wèn)題”。 概括地講,N+1 查詢(xún)問(wèn)題是這樣子的:
你執(zhí)行了一個(gè)單獨(dú)的 SQL 語(yǔ)句來(lái)獲取結(jié)果的一個(gè)列表(就是“+1”)。對(duì)列表返回的每條記錄,你執(zhí)行一個(gè) select 查詢(xún)語(yǔ)句來(lái)為每條記錄加載詳細(xì)信息(就是“N”)。這個(gè)問(wèn)題會(huì)導(dǎo)致成百上千的 SQL 語(yǔ)句被執(zhí)行。有時(shí)候,我們不希望產(chǎn)生這樣的后果。
好消息是,MyBatis 能夠?qū)@樣的查詢(xún)進(jìn)行延遲加載,因此可以將大量語(yǔ)句同時(shí)運(yùn)行的開(kāi)銷(xiāo)分散開(kāi)來(lái)。 然而,如果你加載記錄列表之后立刻就遍歷列表以獲取嵌套的數(shù)據(jù),就會(huì)觸發(fā)所有的延遲加載查詢(xún),性能可能會(huì)變得很糟糕。
方案二
移除collection配置,在業(yè)務(wù)邏輯中進(jìn)行處理。先將參與分頁(yè)的數(shù)據(jù)獲取出來(lái),再根據(jù)需要在業(yè)務(wù)代碼中獲取分頁(yè)數(shù)據(jù)關(guān)聯(lián)的數(shù)據(jù)。博主更傾向于這種方案解決mybatis中collection分頁(yè)問(wèn)題。
擴(kuò)展
Mybatis中配置加載一對(duì)多關(guān)系的兩種方式:
1.集合的嵌套 Select 查詢(xún)
一共會(huì)產(chǎn)生兩個(gè)SQL語(yǔ)句,一個(gè)查詢(xún)主的數(shù)據(jù),另一個(gè)查詢(xún)關(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é)果映射
只會(huì)產(chǎn)品一個(gè)SQL語(yǔ)句,主數(shù)據(jù)以及關(guān)聯(lián)數(shù)據(jù)通過(guò)別名的形式進(jìn)行配置映射到各自的對(duì)象的屬性上。入戲所示:
<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高級(jí)結(jié)果映射ResultMap介紹與使用(包含collection使用)
PageHelper插件重要提示(分頁(yè)插件不支持嵌套結(jié)果映射)
mybatis resultMap之collection聚集兩種實(shí)現(xiàn)方式
到此這篇關(guān)于Mybatis使用collection分頁(yè)問(wèn)題的文章就介紹到這了,更多相關(guān)Mybatis collection分頁(yè)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Mybatis collection查詢(xún)集合屬性報(bào)錯(cuò)的解決方案
- 解決mybatis 中collection嵌套collection引發(fā)的bug
- 詳解mybatis collection標(biāo)簽一對(duì)多的使用
- Mybatis中Collection集合標(biāo)簽的使用詳解
- 詳解mybatis中association和collection的column傳入多個(gè)參數(shù)問(wèn)題
- Mybatis中collection和association的使用區(qū)別詳解
- mybatis 中 foreach collection的用法小結(jié)(三種)
相關(guān)文章
Go Java算法之外觀數(shù)列實(shí)現(xiàn)方法示例詳解
這篇文章主要為大家介紹了Go Java算法外觀數(shù)列實(shí)現(xiàn)的方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08Spring Boot 2.0快速構(gòu)建服務(wù)組件全步驟
這篇文章主要給大家介紹了關(guān)于Spring Boot 2.0快速構(gòu)建服務(wù)組件的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Spring Boot 2.0具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04SpringBoot中打印SQL語(yǔ)句的幾種方法實(shí)現(xiàn)
本文主要介紹了SpringBoot中打印SQL語(yǔ)句的幾種方法實(shí)現(xiàn),,通過(guò)打印SQL語(yǔ)句可以幫助開(kāi)發(fā)人員快速了解數(shù)據(jù)庫(kù)的操作情況,進(jìn)而進(jìn)行性能分析和調(diào)試,感興趣的可以了解一下2023-11-11Java 如何解析key為動(dòng)態(tài)的json操作
這篇文章主要介紹了Java 如何解析key為動(dòng)態(tài)的json操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-02-02java調(diào)用shell命令并獲取執(zhí)行結(jié)果的示例
今天小編就為大家分享一篇java調(diào)用shell命令并獲取執(zhí)行結(jié)果的示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動(dòng)刷新配置的教程
這篇文章主要介紹了Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動(dòng)刷新配置,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09SpringBoot集成Redis的實(shí)現(xiàn)示例
這篇文章主要介紹了SpringBoot集成Redis的實(shí)現(xiàn)示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-11-11基于springboot微信公眾號(hào)開(kāi)發(fā)(微信自動(dòng)回復(fù))
這篇文章主要介紹了基于springboot微信公眾號(hào)開(kāi)發(fā)(微信自動(dòng)回復(fù)),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11Spring boot自定義http反饋狀態(tài)碼詳解
這篇文章主要給大家介紹了Spring boot自定義http反饋狀態(tài)碼的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編一起來(lái)學(xué)習(xí)學(xué)習(xí)吧。2017-06-06