亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > 幫助中心 > 正文

Mybatis之RowBounds分頁原理詳解

2024-07-09 22:43:17
字體:
來源:轉載
供稿:網友

Mybatis可以通過傳遞RowBounds對象,來進行數據庫數據的分頁操作,然而遺憾的是,該分頁操作是對ResultSet結果集進行分頁,也就是人們常說的邏輯分頁,而非物理分頁。

RowBounds對象的源碼如下:

public class RowBounds { public static final int NO_ROW_OFFSET = 0; public static final int NO_ROW_LIMIT = Integer.MAX_VALUE; public static final RowBounds DEFAULT = new RowBounds(); private int offset; private int limit; public RowBounds() {  this.offset = NO_ROW_OFFSET;  this.limit = NO_ROW_LIMIT; } public RowBounds(int offset, int limit) {  this.offset = offset;  this.limit = limit; } public int getOffset() {  return offset; } public int getLimit() {  return limit; }}

對數據庫數據進行分頁,依靠offset和limit兩個參數,表示從第幾條開始,取多少條。也就是人們常說的start,limit。

下面看看Mybatis的如何進行分頁的。

org.apache.ibatis.executor.resultset.DefaultResultSetHandler.handleRowValuesForSimpleResultMap()方法源碼。

 private void handleRowValuesForSimpleResultMap(ResultSetWrapper rsw, ResultMap resultMap, ResultHandler<?> resultHandler, RowBounds rowBounds, ResultMapping parentMapping)   throws SQLException {  DefaultResultContext<Object> resultContext = new DefaultResultContext<Object>();  // 跳到offset位置,準備讀取  skipRows(rsw.getResultSet(), rowBounds);  // 讀取limit條數據  while (shouldProcessMoreRows(resultContext, rowBounds) && rsw.getResultSet().next()) {   ResultMap discriminatedResultMap = resolveDiscriminatedResultMap(rsw.getResultSet(), resultMap, null);   Object rowValue = getRowValue(rsw, discriminatedResultMap);   storeObject(resultHandler, resultContext, rowValue, parentMapping, rsw.getResultSet());  } }   private void skipRows(ResultSet rs, RowBounds rowBounds) throws SQLException {  if (rs.getType() != ResultSet.TYPE_FORWARD_ONLY) {   if (rowBounds.getOffset() != RowBounds.NO_ROW_OFFSET) {    // 直接定位    rs.absolute(rowBounds.getOffset());   }  } else {   // 只能逐條滾動到指定位置   for (int i = 0; i < rowBounds.getOffset(); i++) {    rs.next();   }  } }

說明,Mybatis的分頁是對結果集進行的分頁。

假設查詢結果總共是100條記錄,而我們只需要分頁后的10條,是不是意味著100條記錄在內存中,我們對內存分頁獲得了10條數據呢?

非也,JDBC驅動并不是把所有結果加載至內存中,而是只加載小部分數據至內存中,如果還需要從數據庫中取更多記錄,它會再次去獲取部分數據,這就是fetch size的用處。和我們從銀行卡里取錢是一個道理,卡里的錢都是你的,但是我們一次取200元,用完不夠再去取,此時我們的fetch size = 200元。

因此,Mybatis的邏輯分頁性能,并不像很多人想的那么差,很多人認為是對內存進行的分頁。

最優方案,自然是物理分頁了,也就是查詢結果,就是我們分頁后的結果,性能是最好的。如果你一定要物理分頁,該如何解決呢?

1. Sql中帶有offset,limit參數,自己控制參數值,直接查詢分頁結果。

2. 使用第三方開發的Mybatis分頁插件。

3. 修改Mybatis源碼,給Sql追加自己的物理分頁Subsql。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網之家。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲а∨天堂久久精品9966| 国产精品极品美女在线观看免费| 18久久久久久| 最好看的2019的中文字幕视频| 国产精品白丝av嫩草影院| 亚洲在线一区二区| 国产精品日韩在线观看| 国产精品成人播放| 亚洲人成电影网站色…| 亚洲第一区第一页| 丝袜美腿亚洲一区二区| 亚洲国产私拍精品国模在线观看| 久久久久久这里只有精品| 亚洲国产精品va在线看黑人| 久久久www成人免费精品| 日韩男女性生活视频| 欧美性猛交xxxxx水多| 日韩有码在线电影| 午夜精品一区二区三区在线视| 2018日韩中文字幕| 久久久久国产精品www| 欧美午夜视频一区二区| 久久频这里精品99香蕉| 中文字幕日韩欧美精品在线观看| 成人两性免费视频| 成人a免费视频| 国内偷自视频区视频综合| 国产精品吊钟奶在线| 欧美激情二区三区| 亚洲精品成人av| 岛国av在线不卡| 黑人巨大精品欧美一区二区三区| 久久久中文字幕| 91精品国产高清自在线| 一区国产精品视频| 亚洲精品www久久久| 日本成熟性欧美| 欧美在线不卡区| 日韩在线中文视频| 国产精品99蜜臀久久不卡二区| 亚洲欧美日韩区| 日本韩国欧美精品大片卡二| 欧美性猛交xxxx免费看漫画| 久久不射热爱视频精品| 日韩精品免费在线| 人体精品一二三区| 91免费版网站入口| 精品亚洲一区二区三区在线播放| 欧美巨乳在线观看| 91最新在线免费观看| 精品久久久久久中文字幕大豆网| 亚洲精品自产拍| 亚洲国产精品视频在线观看| 国内偷自视频区视频综合| 国产亚洲精品久久久优势| 成人在线视频福利| 黑人极品videos精品欧美裸| 精品伊人久久97| 亚洲图片在线综合| 国内精品400部情侣激情| 精品国产乱码久久久久久婷婷| 91精品中文在线| 亚洲三级 欧美三级| 精品色蜜蜜精品视频在线观看| 中文字幕精品网| 欧美视频二区36p| 国产精品稀缺呦系列在线| 亚洲一级一级97网| 午夜精品一区二区三区在线| 97精品视频在线播放| 九九热这里只有精品免费看| 日韩最新中文字幕电影免费看| 性色av一区二区三区| 日韩精品免费综合视频在线播放| 庆余年2免费日韩剧观看大牛| 国产91精品高潮白浆喷水| 日韩免费在线看| 日日狠狠久久偷偷四色综合免费| 国产精品电影网| 国产精品久久久久高潮| 精品国内产的精品视频在线观看| 国产精品免费久久久久影院| 亚洲色图13p| 欧美激情国产日韩精品一区18| 色综合伊人色综合网| 91精品久久久久久久久久久久久| 成人国产精品久久久久久亚洲| 欧美电影免费观看| 全球成人中文在线| 色香阁99久久精品久久久| 97精品国产97久久久久久免费| 伊人久久久久久久久久久| 98视频在线噜噜噜国产| 日韩美女免费线视频| 一区二区三区亚洲| 国产欧美欧洲在线观看| 久久免费视频观看| 欧美日韩国产二区| 69久久夜色精品国产7777| 亚洲精品xxxx| 美女精品视频一区| 亚洲午夜av电影| 欧美激情18p| 久久6免费高清热精品| 亚洲精品网址在线观看| 国产精品91在线观看| 午夜剧场成人观在线视频免费观看| 日韩一区视频在线| 日韩电影在线观看永久视频免费网站| 青青草精品毛片| 尤物九九久久国产精品的分类| 日韩少妇与小伙激情| 日韩中文字幕在线看| 久久久久国产精品一区| 国产精品视频xxxx| 91精品免费久久久久久久久| 欧美精品videos性欧美| 欧美成人精品三级在线观看| 亚洲xxx视频| 亚洲欧美综合另类中字| 精品久久久久久中文字幕| 亚洲天堂男人天堂女人天堂| 日韩女优人人人人射在线视频| 国产成人精品免高潮费视频| 亚洲最大成人网色| 亚洲综合av影视| 日韩av免费观影| 91美女片黄在线观| 欧美色视频日本高清在线观看| 亚洲女在线观看| 国产精品综合网站| 国产精品视频成人| 亚洲天堂精品在线| 亚洲精品国产精品乱码不99按摩| 欧美在线不卡区| 国产精品丝袜久久久久久不卡| 欧美亚洲在线视频| 色老头一区二区三区| 日韩亚洲欧美中文高清在线| 亚洲一区国产精品| 亚洲成人网久久久| 欧美性生活大片免费观看网址| 久久久999国产精品| 欧美午夜xxx| 日韩大陆欧美高清视频区| 亚洲欧美日韩直播| 成人动漫网站在线观看| 久久五月天综合| 国产一区欧美二区三区| 亚洲国产美女精品久久久久∴| 亚洲一区二区少妇| 波霸ol色综合久久| 成人免费看黄网站| 国产亚洲欧美一区| 亚洲一区二区三区成人在线视频精品| 亚洲电影免费观看高清完整版在线| 精品国产一区二区三区久久狼黑人| 亚洲国产精品大全| 亚洲人成电影网站色…| 狠狠色狠色综合曰曰| 日韩在线小视频| 欧美激情精品久久久久久蜜臀| 色综合色综合久久综合频道88| 亚洲精品在线不卡|