亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java?3年面試經(jīng)驗(yàn)告訴你Mybatis是如何進(jìn)行分頁(yè)的

 更新時(shí)間:2022年09月22日 10:32:43   作者:跟著Mic學(xué)架構(gòu)  
這篇文章主要介紹了Java?3年面試經(jīng)驗(yàn)告訴你Mybatis是如何進(jìn)行分頁(yè)的,對(duì)于任何ORM框架,分頁(yè)的實(shí)現(xiàn)邏輯無(wú)外乎兩種,不管怎么包裝,最終給到開(kāi)發(fā)者的,只是使用上的差異而已,本文給大家講解的很明白,感興趣的朋友一起看看吧

“Mybatis是如何進(jìn)行分頁(yè)的”?

這是一個(gè)工作了3年的同學(xué),在面試的時(shí)候遇到的問(wèn)題。

大家好,我是Mic,一個(gè)工作了14年的Java程序員。

經(jīng)常有同學(xué)在后臺(tái)跟我吐槽,在求職過(guò)程中遇到的各種面試難題。

我發(fā)現(xiàn)大部分的問(wèn)題之前的文章都有分析過(guò)。

考慮到視頻可能太過(guò)分散,不方便大家學(xué)習(xí) 所以我系統(tǒng)整理了一份20萬(wàn)字的文檔有需要的掃碼最底下領(lǐng)取。

下面我們來(lái)分析一下面試官對(duì)于這個(gè)問(wèn)題的考察意圖。

考察目標(biāo)

Mybatis是Java應(yīng)用開(kāi)發(fā)的基礎(chǔ)框架,而分頁(yè)又是我們實(shí)時(shí)都在使用的功能。

因此,在我看來(lái),一方面考察的是求職者對(duì)Mybatis框架的使用能力。

另一方面,以此為切入點(diǎn)去深度挖掘Mybatis里面更多的問(wèn)題,從而了解求職者對(duì)它的理解深度。

這道題考察難度不大,主要考察1-3年Java開(kāi)發(fā)經(jīng)驗(yàn)的同學(xué)。

問(wèn)題解析

數(shù)據(jù)進(jìn)行分頁(yè)是最基礎(chǔ)的功能,一般可以把分頁(yè)分成兩類:

  • 邏輯分頁(yè),先查詢出所有的數(shù)據(jù)緩存到內(nèi)存,再根據(jù)業(yè)務(wù)相關(guān)需求,從內(nèi)存數(shù)據(jù)中篩選出合適的數(shù)據(jù)進(jìn)行分頁(yè)。
  • 物理分頁(yè) ,直接利用數(shù)據(jù)庫(kù)支持的分頁(yè)語(yǔ)法來(lái)實(shí)現(xiàn),比如Mysql里面提供了分頁(yè)關(guān)鍵詞Limit

Mybatis提供了四種分頁(yè)方式:

  • 在Mybatis Mapper配置文件里面直接寫(xiě)分頁(yè)SQL,這種方式比較靈活,實(shí)現(xiàn)也簡(jiǎn)單。
  • RowBounds實(shí)現(xiàn)邏輯分頁(yè),也就是一次性加載所有符合查詢條件的目標(biāo)數(shù)據(jù),根據(jù)分頁(yè)參數(shù)值在內(nèi)存中實(shí)現(xiàn)分頁(yè)。

當(dāng)然,在數(shù)據(jù)量比較大的情況下,JDBC驅(qū)動(dòng)本身會(huì)做一些優(yōu)化,也就是不會(huì)把所有結(jié)果存儲(chǔ)在ResultSet里面,而是只加載一部分?jǐn)?shù)據(jù),再根據(jù)需求去數(shù)據(jù)庫(kù)里面加載。

這種方式不適合數(shù)據(jù)量較大的場(chǎng)景,而且有可能會(huì)頻繁訪問(wèn)數(shù)據(jù)庫(kù)造成比較大的壓力。

  • Interceptor攔截器實(shí)現(xiàn),通過(guò)攔截需要分頁(yè)的select語(yǔ)句,然后在這個(gè)sql語(yǔ)句里面動(dòng)態(tài)拼接分頁(yè)關(guān)鍵字,從而實(shí)現(xiàn)分頁(yè)查詢。

Interceptor是Mybatis提供的一種針對(duì)不同生命周期的攔截器,比如:

  • 攔截執(zhí)行器方法
  • 攔截參數(shù)的處理
  • 攔截結(jié)果集的處理
  • 攔截SQL語(yǔ)法構(gòu)建的處理

我們可以攔截不同階段的處理,來(lái)實(shí)現(xiàn)Mybatis相關(guān)功能的擴(kuò)展。

這種方式的好處,就是可以提供統(tǒng)一的處理機(jī)制,不需要我們?cè)賳为?dú)去維護(hù)分頁(yè)相關(guān)的功能。

  • 插件(PageHelper)及(MyBaits-Plus、tkmybatis)框架實(shí)現(xiàn)這些插件本質(zhì)上也是使用Mybatis的攔截器來(lái)實(shí)現(xiàn)的。

只是他們幫我們實(shí)現(xiàn)了擴(kuò)展和封裝,節(jié)省了分頁(yè)擴(kuò)展封裝的工作量,在實(shí)際開(kāi)發(fā)中,只需要拿來(lái)即用即可。

總結(jié)一下,對(duì)于任何ORM框架,分頁(yè)的實(shí)現(xiàn)邏輯無(wú)外乎兩種,不管怎么包裝,最終給到開(kāi)發(fā)者的,只是使用上的差異而已。

那么,我們來(lái)看看高手該如何回答。

高手:

我認(rèn)為有三種方式來(lái)實(shí)現(xiàn)分頁(yè):

  • 第一種,直接在Select語(yǔ)句上增加數(shù)據(jù)庫(kù)提供的分頁(yè)關(guān)鍵字,然后在應(yīng)用程序里面?zhèn)鬟f當(dāng)前頁(yè),以及每頁(yè)展示條數(shù)即可。
  • 第二種,使用Mybatis提供的RowBounds對(duì)象,實(shí)現(xiàn)內(nèi)存級(jí)別分頁(yè)。
  • 第三種,基于Mybatis里面的Interceptor攔截器,在select語(yǔ)句執(zhí)行之前動(dòng)態(tài)拼接分頁(yè)關(guān)鍵字。

總結(jié)

大家知道怎么回答了嗎?

到此這篇關(guān)于Java 3年面試經(jīng)驗(yàn)告訴你Mybatis是如何進(jìn)行分頁(yè)的的文章就介紹到這了,更多相關(guān)mybatis分頁(yè)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

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

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

    這篇文章主要介紹了Spring Security CsrfFilter過(guò)濾器用法實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • 詳解Java8?StreamAPI中的map()方法

    詳解Java8?StreamAPI中的map()方法

    Stream?API?是Java8中新加入的功能,這篇文章主要帶大家了解一下?Stream?API?中的?map()?方法的使用,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-04-04
  • javaweb實(shí)現(xiàn)app掃碼登錄功能

    javaweb實(shí)現(xiàn)app掃碼登錄功能

    這篇文章主要為大家詳細(xì)介紹了javaweb實(shí)現(xiàn)app掃碼登錄功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • Java使用Arrays.asList報(bào)UnsupportedOperationException的解決

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

    這篇文章主要介紹了Java使用Arrays.asList報(bào)UnsupportedOperationException的解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 深入理解spring的AOP機(jī)制原理

    深入理解spring的AOP機(jī)制原理

    本篇文章主要介紹了深入理解spring的AOP機(jī)制原理,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • SpringBoot 使用 Ehcache 作為緩存的操作方法

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

    這篇文章主要介紹了SpringBoot 如何使用 Ehcache 作為緩存,我們通過(guò)添加 Ehcache 依賴、創(chuàng)建 Ehcache 配置文件并在 Spring Boot 應(yīng)用程序的配置文件中啟用 Ehcache 緩存,來(lái)配置 Ehcache 緩存,需要的朋友可以參考下
    2023-06-06
  • java+selenium 網(wǎng)易云音樂(lè)刷累計(jì)聽(tīng)歌數(shù)的方法

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

    這篇文章主要介紹了java+selenium 網(wǎng)易云音樂(lè)刷累計(jì)聽(tīng)歌數(shù)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 解決IDEA service層跳轉(zhuǎn)實(shí)現(xiàn)類的快捷圖標(biāo)消失問(wèn)題

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

    這篇文章主要介紹了解決IDEA service層跳轉(zhuǎn)實(shí)現(xiàn)類的快捷圖標(biāo)消失問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-02-02
  • 詳談Java中instanceof和isInstance的區(qū)別

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

    下面小編就為大家?guī)?lái)一篇詳談Java中instanceof和isInstance的區(qū)別。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-01-01
  • 最新評(píng)論