91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

如何在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

郓城县| 农安县| 浮梁县| 津南区| 紫云| 竹山县| 靖江市| 民丰县| 靖边县| 济宁市| 庄河市| 桂林市| 德昌县| 望都县| 宣城市| 凌云县| 博白县| 安顺市| 景谷| 玛多县| 保德县| 滨州市| 宝丰县| 定远县| 铅山县| 牡丹江市| 马鞍山市| 定襄县| 明水县| 江都市| 辽阳县| 伊通| 大邑县| 泰兴市| 宁南县| 广水市| 垦利县| 天峻县| 治多县| 巴彦县| 寻乌县|