Java?3年面試經(jīng)驗(yàn)告訴你Mybatis是如何進(jìn)行分頁的
“Mybatis是如何進(jìn)行分頁的”?
這是一個(gè)工作了3年的同學(xué),在面試的時(shí)候遇到的問題。
大家好,我是Mic,一個(gè)工作了14年的Java程序員。
經(jīng)常有同學(xué)在后臺跟我吐槽,在求職過程中遇到的各種面試難題。
我發(fā)現(xiàn)大部分的問題之前的文章都有分析過。
考慮到視頻可能太過分散,不方便大家學(xué)習(xí) 所以我系統(tǒng)整理了一份20萬字的文檔有需要的掃碼最底下領(lǐng)取。
下面我們來分析一下面試官對于這個(gè)問題的考察意圖。
考察目標(biāo)
Mybatis是Java應(yīng)用開發(fā)的基礎(chǔ)框架,而分頁又是我們實(shí)時(shí)都在使用的功能。
因此,在我看來,一方面考察的是求職者對Mybatis框架的使用能力。
另一方面,以此為切入點(diǎn)去深度挖掘Mybatis里面更多的問題,從而了解求職者對它的理解深度。
這道題考察難度不大,主要考察1-3年Java開發(fā)經(jīng)驗(yàn)的同學(xué)。
問題解析
數(shù)據(jù)進(jìn)行分頁是最基礎(chǔ)的功能,一般可以把分頁分成兩類:
- 邏輯分頁,先查詢出所有的數(shù)據(jù)緩存到內(nèi)存,再根據(jù)業(yè)務(wù)相關(guān)需求,從內(nèi)存數(shù)據(jù)中篩選出合適的數(shù)據(jù)進(jìn)行分頁。
- 物理分頁 ,直接利用數(shù)據(jù)庫支持的分頁語法來實(shí)現(xiàn),比如Mysql里面提供了分頁關(guān)鍵詞Limit
Mybatis提供了四種分頁方式:
- 在Mybatis Mapper配置文件里面直接寫分頁SQL,這種方式比較靈活,實(shí)現(xiàn)也簡單。
- RowBounds實(shí)現(xiàn)邏輯分頁,也就是一次性加載所有符合查詢條件的目標(biāo)數(shù)據(jù),根據(jù)分頁參數(shù)值在內(nèi)存中實(shí)現(xiàn)分頁。
當(dāng)然,在數(shù)據(jù)量比較大的情況下,JDBC驅(qū)動(dòng)本身會做一些優(yōu)化,也就是不會把所有結(jié)果存儲在ResultSet里面,而是只加載一部分?jǐn)?shù)據(jù),再根據(jù)需求去數(shù)據(jù)庫里面加載。
這種方式不適合數(shù)據(jù)量較大的場景,而且有可能會頻繁訪問數(shù)據(jù)庫造成比較大的壓力。
- Interceptor攔截器實(shí)現(xiàn),通過攔截需要分頁的select語句,然后在這個(gè)sql語句里面動(dòng)態(tài)拼接分頁關(guān)鍵字,從而實(shí)現(xiàn)分頁查詢。
Interceptor是Mybatis提供的一種針對不同生命周期的攔截器,比如:
- 攔截執(zhí)行器方法
- 攔截參數(shù)的處理
- 攔截結(jié)果集的處理
- 攔截SQL語法構(gòu)建的處理
我們可以攔截不同階段的處理,來實(shí)現(xiàn)Mybatis相關(guān)功能的擴(kuò)展。
這種方式的好處,就是可以提供統(tǒng)一的處理機(jī)制,不需要我們再單獨(dú)去維護(hù)分頁相關(guān)的功能。
- 插件(PageHelper)及(MyBaits-Plus、tkmybatis)框架實(shí)現(xiàn)這些插件本質(zhì)上也是使用Mybatis的攔截器來實(shí)現(xiàn)的。
只是他們幫我們實(shí)現(xiàn)了擴(kuò)展和封裝,節(jié)省了分頁擴(kuò)展封裝的工作量,在實(shí)際開發(fā)中,只需要拿來即用即可。
總結(jié)一下,對于任何ORM框架,分頁的實(shí)現(xiàn)邏輯無外乎兩種,不管怎么包裝,最終給到開發(fā)者的,只是使用上的差異而已。
那么,我們來看看高手該如何回答。
高手:
我認(rèn)為有三種方式來實(shí)現(xiàn)分頁:
- 第一種,直接在Select語句上增加數(shù)據(jù)庫提供的分頁關(guān)鍵字,然后在應(yīng)用程序里面?zhèn)鬟f當(dāng)前頁,以及每頁展示條數(shù)即可。
- 第二種,使用Mybatis提供的RowBounds對象,實(shí)現(xiàn)內(nèi)存級別分頁。
- 第三種,基于Mybatis里面的Interceptor攔截器,在select語句執(zhí)行之前動(dòng)態(tài)拼接分頁關(guān)鍵字。
總結(jié)
大家知道怎么回答了嗎?
到此這篇關(guān)于Java 3年面試經(jīng)驗(yàn)告訴你Mybatis是如何進(jìn)行分頁的的文章就介紹到這了,更多相關(guān)mybatis分頁內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章

Spring Security CsrfFilter過濾器用法實(shí)例

Java使用Arrays.asList報(bào)UnsupportedOperationException的解決

SpringBoot 使用 Ehcache 作為緩存的操作方法

java+selenium 網(wǎng)易云音樂刷累計(jì)聽歌數(shù)的方法

解決IDEA service層跳轉(zhuǎn)實(shí)現(xiàn)類的快捷圖標(biāo)消失問題

詳談Java中instanceof和isInstance的區(qū)別