中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在MyBatis中使用PageHelper分頁插件

發布時間:2021-06-09 18:02:08 來源:億速云 閱讀:189 作者:Leah 欄目:編程語言

這篇文章給大家介紹如何在MyBatis中使用PageHelper分頁插件,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

PageHelper的使用

優點:無需你自己去封裝以及關心sql分頁等問題,使用很方便,前端取數據也很方便。

1.引入pagehelper依賴

<dependency>
  <groupId>com.github.pagehelper</groupId>
  <artifactId>pagehelper</artifactId>
  <version>5.1.2<ersion>
</dependency>

2.配置applicationContext.xml文件

在spring的sqlsessionfactorybean中增加一個分頁攔截器屬性
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  <property name="plugins">
        <array>
          <bean class="com.github.pagehelper.PageInterceptor">
            <property name="properties">
              <value>
                <!-- 這里設定你的數據庫類型 -->
                helperDialect=mysql
              </value>
            </property>
          </bean>
        </array>
  </property>
</bean>

3.調用PageHelper的方法

在service方法中調用PageHelper的靜態方法startPage(注意一定要在實際查詢數據庫之前調用該方法),傳入需要查詢的頁號和每頁大小,返回PageHelper插件提供的PageInfo對象。即可自動完成數據庫物理分頁,無須在你的sql語句中手工加limit子句

如何在MyBatis中使用PageHelper分頁插件

4. PageInfo的結構

關于PageInfo的結構請參看源碼,這里通過返回的json來展示。根據需要取PageInfo對象的相應屬性即可。

如何在MyBatis中使用PageHelper分頁插件

5.PageInfo類說明

類源碼(更多源碼去github上查看即可):

public class PageInfo<T> implements Serializable {
  private static final long serialVersionUID = 1L;
  //當前頁
  private int pageNum;
  //每頁的數量
  private int pageSize;
  //當前頁的數量
  private int size;
 
  //由于startRow和endRow不常用,這里說個具體的用法
  //可以在頁面中"顯示startRow到endRow 共size條數據"
 
  //當前頁面第一個元素在數據庫中的行號
  private int startRow;
  //當前頁面最后一個元素在數據庫中的行號
  private int endRow;
  //總記錄數
  private long total;
  //總頁數
  private int pages;
  //結果集
  private List<T> list;
 
  //前一頁
  private int prePage;
  //下一頁
  private int nextPage;
 
  //是否為第一頁
  private boolean isFirstPage = false;
  //是否為最后一頁
  private boolean isLastPage = false;
  //是否有前一頁
  private boolean hasPreviousPage = false;
  //是否有下一頁
  private boolean hasNextPage = false;
  //導航頁碼數
  private int navigatePages;
  //所有導航頁號
  private int[] navigatepageNums;
  //導航條上的第一頁
  private int navigateFirstPage;
  //導航條上的最后一頁
  private int navigateLastPage;
 
  public PageInfo() {
  }
 
  /**
   * 包裝Page對象
   *
   * @param list
   */
  public PageInfo(List<T> list) {
    this(list, 8);
  }
 
  /**
   * 包裝Page對象
   *
   * @param list     page結果
   * @param navigatePages 頁碼數量
   */
  public PageInfo(List<T> list, int navigatePages) {
    if (list instanceof Page) {
      Page page = (Page) list;
      this.pageNum = page.getPageNum();
      this.pageSize = page.getPageSize();
 
      this.pages = page.getPages();
      this.list = page;
      this.size = page.size();
      this.total = page.getTotal();
      //由于結果是>startRow的,所以實際的需要+1
      if (this.size == 0) {
        this.startRow = 0;
        this.endRow = 0;
      } else {
        this.startRow = page.getStartRow() + 1;
        //計算實際的endRow(最后一頁的時候特殊)
        this.endRow = this.startRow - 1 + this.size;
      }
    } else if (list instanceof Collection) {
      this.pageNum = 1;
      this.pageSize = list.size();
 
      this.pages = this.pageSize > 0 ? 1 : 0;
      this.list = list;
      this.size = list.size();
      this.total = list.size();
      this.startRow = 0;
      this.endRow = list.size() > 0 ? list.size() - 1 : 0;
    }
    if (list instanceof Collection) {
      this.navigatePages = navigatePages;
      //計算導航頁
      calcNavigatepageNums();
      //計算前后頁,第一頁,最后一頁
      calcPage();
      //判斷頁面邊界
      judgePageBoudary();
    }
  }
 
 
.......
}

關于如何在MyBatis中使用PageHelper分頁插件就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

龙江县| 元江| 福泉市| 湘潭市| 雷州市| 嘉黎县| 肥乡县| 拉萨市| 大庆市| 璧山县| 吉水县| 天津市| 宜都市| 黔南| 衡东县| 福海县| 樟树市| 许昌市| 巩留县| 邵阳市| 黑水县| 阜城县| 邵武市| 上林县| 龙门县| 绥棱县| 滕州市| 荆州市| 宿迁市| 宜春市| 客服| 旬邑县| 荥经县| 进贤县| 兰溪市| 牙克石市| 星子县| 大城县| 沅江市| 阿鲁科尔沁旗| 昌平区|