天天看點

Springboot Mybatis使用pageHelper實作分頁查詢

以下介紹實戰中資料庫架構使用的是mybatis,對整合mybatis此處不做介紹。

使用pageHelper實作分頁查詢其實非常簡單,共兩步:

一、導入依賴;   

二、添加配置;   

那麼開始,

第一步:

pom.xml添加依賴:

<!--分頁插件 pagehelper -->
<dependency>
   <groupId>com.github.pagehelper</groupId>
   <artifactId>pagehelper-spring-boot-starter</artifactId>
   <!-- 特别注意版本問題 -->
   <version>1.2.3</version>
</dependency>      

 第二步:

aplication.yml添加配置:

#分頁pageHelper
pagehelper:
  helper-dialect: mysql
  reasonable: true
  support-methods-arguments: true      

helper-dialect:

配置使用哪種資料庫語言,不配置的話pageHelper也會自動檢測

·reasonable:

配置分頁參數合理化功能,預設是false。 #啟用合理化時,如果pageNum<1會查詢第一頁,如果pageNum>總頁數會查詢最後一頁; #禁用合理化時,如果pageNum<1或pageNum>總頁數會傳回空資料。

·params:

為了支援startPage(Object params)方法,增加了該參數來配置參數映射,用于從對象中根據屬性名取值; 可以配置 pageNum,pageSize,count,pageSizeZero,reasonable,不配置映射的用預設值, 預設值為pageNum=pageNum;pageSize=pageSize;count=countSql;reasonable=reasonable;pageSizeZero=pageSizeZero。

·support-methods-arguments:

支援通過Mapper接口參數來傳遞分頁參數,預設值false,分頁插件會從查詢方法的參數值中,自動根據上面 params 配置的字段中取值,查找到合适的值時就會自動分頁。

第三步,

先将需要查詢的資料庫表建起來,簡單填充資料:

Springboot Mybatis使用pageHelper實作分頁查詢

然後mapper層寫上查詢該表資料傳回List的方法:

//查詢所有
List<User> queryUserInfo();      

在service以及impl也寫上相關方法:

//查詢所有
List<User> queryUserInfo();      
@Override
public List<User> queryUserInfo() {

    return userMapper.queryUserInfo();
}      

相關的mapper.xml就不做過多介紹了,就是一個查詢。

ok,接下來開始使用分頁插件,配合上面的查詢實作分頁查詢:

在userService上添加 分頁查詢方法2個:

List<User> findAllUserByPageF(int pageNum,int pageSize);

PageInfo<User> findAllUserByPageS(int pageNum, int pageSize);      

userServiceImpl上添加 分頁查詢實作:

@Override
public List<User> findAllUserByPageF(int pageNum, int pageSize) {
    // TODO Auto-generated method stub
    PageHelper.startPage(pageNum, pageSize);
    List<User> lists = userMapper.queryUserInfo();
    return lists;
}

@Override
public PageInfo<User> findAllUserByPageS(int pageNum, int pageSize) {
    // TODO Auto-generated method stub
    PageHelper.startPage(pageNum, pageSize);
    List<User> lists = userMapper.queryUserInfo();
    PageInfo<User> pageInfo = new PageInfo<User>(lists);
    return pageInfo;

}      

最後在controller寫上測試接口,

@GetMapping("/testPageHelper1")
public PageInfo<User> testPageHelper1(){
    PageInfo<User> queryResult = userService.findAllUserByPageS(1, 5);
    return queryResult;
}

@GetMapping("/testPageHelper2")
public List<User> testPageHelper2(){
    List<User> queryResult = userService.findAllUserByPageF(1, 5);
    return queryResult;
}      

然後用POSTMAN 分别調接口看看結果:

Springboot Mybatis使用pageHelper實作分頁查詢
Springboot Mybatis使用pageHelper實作分頁查詢

最後附上分别調用10次的性能分析簡圖(來自DRUID):

Springboot Mybatis使用pageHelper實作分頁查詢

OK,簡單實戰介紹到此吧。

繼續閱讀