欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java后端實現(xiàn)信息分頁查詢的示例代碼

 更新時間:2023年11月30日 11:01:42   作者:D. D  
在一個頁面展示大量的用戶信息不便于觀看,因此就需要采用分頁展示的方法,本文就來為大家介紹一下java后端如何實現(xiàn)信息分頁查詢,需要的小伙伴可以參考下

需求分析

在一個頁面展示大量的用戶信息不便于觀看,因此采用分頁展示的方法。

用戶可以通過分頁條自己選擇查看的數(shù)量。

可以用條件過濾一些信息,在查詢的同時還需要分頁展示

代碼開發(fā)

1.流程

頁面發(fā)送ajax請求,將分頁查詢參數(shù)(page,pageSize,name)提交到服務端

服務端Controller接收到頁面提交的數(shù)據(jù)并調(diào)用Service查詢數(shù)據(jù)

Service調(diào)用Mapper操作數(shù)據(jù)庫,查詢分頁展示

Controller將查詢到的分頁數(shù)據(jù)響應給頁面

頁面接收到分頁數(shù)據(jù)并通過ElementUI的Table組件展示到頁面上

2.要點說明

全局請求攔截器,發(fā)送get方式ajax請求,json格式的參數(shù)會統(tǒng)一進行處理,重新組裝。

最終格式:http://localhost:8080/employee/page?page=1&pageSize=10

    // request攔截器
   service.interceptors.request.use(config => {
    // 是否需要設置 token
    // const isToken = (config.headers || {}).isToken === false
    // if (getToken() && !isToken) {
    //   config.headers['Authorization'] = 'Bearer ' + getToken() // 讓每個請求攜帶自定義token 請根據(jù)實際情況自行修改
    // }
    // get請求映射params參數(shù)
    if (config.method === 'get' && config.params) {
      let url = config.url + '?';
      for (const propName of Object.keys(config.params)) {
        const value = config.params[propName];
        var part = encodeURIComponent(propName) + "=";
        if (value !== null && typeof(value) !== "undefined") {
          if (typeof value === 'object') {
            for (const key of Object.keys(value)) {
              let params = propName + '[' + key + ']';
              var subPart = encodeURIComponent(params) + "=";
              url += subPart + encodeURIComponent(value[key]) + "&";
            }
          } else {
            url += part + encodeURIComponent(value) + "&";
          }
        }
      }
      url = url.slice(0, -1);
      config.params = {};
      config.url = url;
    }
    return config
  }, error => {
      console.log(error)
      Promise.reject(error)
  })  

前端響應攔截器

    // 響應攔截器
service.interceptors.response.use(res => {
  if (res.data.code === 0 && res.data.msg === 'NOTLOGIN') {// 返回登錄頁面
    console.log('---/backend/page/login/login.html---')
    localStorage.removeItem('userInfo')
    window.top.location.href = '/backend/page/login/login.html'
  } else {
    return res.data
  }
},
error => {
  console.log('err' + error)
  let { message } = error;
  if (message == "Network Error") {
    message = "后端接口連接異常";
  }
  else if (message.includes("timeout")) {
    message = "系統(tǒng)接口請求超時";
  }
  else if (message.includes("Request failed with status code")) {
    message = "系統(tǒng)接口" + message.substr(message.length - 3) + "異常";
  }
  window.ELEMENT.Message({
    message: message,
    type: 'error',
    duration: 5 * 1000
  })
  return Promise.reject(error)
}
)

前后端對接的數(shù)據(jù)需要統(tǒng)一

3.后端代碼開發(fā)

配置Mybatis-plus的分頁插件

/**
 * 配置MP的分頁插件
 */
@Configuration //配置類注解
public class MybatisPlusConfig {

    //通過攔截器的方式將插件加載到項目
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor(){
        //創(chuàng)建攔截器對象
        MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
        //通過對象加載攔截器
        mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor());
        return mybatisPlusInterceptor;
    }
}

創(chuàng)建controller類接收前端頁面發(fā)送請求的參數(shù)

/**
 * 員工信息的分頁查詢
 * @param page
 * @param pageSize
 * @param name
 * @return
 */
@GetMapping("/page")
public R<Page> page(int page,int pageSize,String name) {
    log.info("page={},pageSize={},name={}", page, pageSize, name);

    //1.構造分頁構造器
    Page pageInfo = new Page<>(page, pageSize);

    //2.構造條件構造器
    LambdaQueryWrapper<Employee> queryWrapper = new LambdaQueryWrapper();
    // 2.1添加一個過濾條件
    queryWrapper.like(StringUtils.isNotEmpty(name), Employee::getName, name);
    // 2.2添加一個排序條件
    queryWrapper.orderByDesc(Employee::getUpdateTime);


    //3.執(zhí)行查詢
    employeeService.page(pageInfo, queryWrapper);
    return R.success(pageInfo);
}

測試

使用斷點調(diào)試,跟蹤代碼邏輯,驗證是否符合預期

到此這篇關于java后端實現(xiàn)信息分頁查詢的示例代碼的文章就介紹到這了,更多相關java分頁查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 深入解析Java的Servlet過濾器的原理及其應用

    深入解析Java的Servlet過濾器的原理及其應用

    這篇文章主要介紹了深入解析Java的Servlet過濾器的原理及應用,Java編寫的Servlet通常是一個與網(wǎng)頁一起作用于瀏覽器客戶端的程序,需要的朋友可以參考下
    2016-01-01
  • MybatisPlus查詢條件空字符串和NULL問題背景分析

    MybatisPlus查詢條件空字符串和NULL問題背景分析

    文章詳細分析了MybatisPlus在處理查詢條件時,空字符串和NULL值的問題,MP 3.3.0及以上版本提供了多種解決方法,包括在Bean屬性上使用注解、全局配置等,推薦使用全局配置的方式來解決這個問題,以避免在SQL查詢中出現(xiàn)不必要的空字符串條件,感興趣的朋友跟隨小編一起看看吧
    2025-03-03
  • 淺談resultMap的用法及關聯(lián)結果集映射

    淺談resultMap的用法及關聯(lián)結果集映射

    這篇文章主要介紹了resultMap的用法及關聯(lián)結果集映射操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • java繼承學習之super的用法解析

    java繼承學習之super的用法解析

    本文介紹java繼承super的用法,Java繼承是會用已存在的類的定義作為基礎建立新類的技術新類的定義可以增加新的數(shù)據(jù)或者新的功能,也可以使用父類的功能,但不能選擇性的繼承父類 這種繼承使得復用以前的代碼非常容易,能夠大大的縮短開發(fā)的周期,需要的朋友可以參考下
    2022-02-02
  • java.util.Random和concurrent.ThreadLocalRandom使用對比

    java.util.Random和concurrent.ThreadLocalRandom使用對比

    這篇文章主要介紹了java.util.Random和concurrent.ThreadLocalRandom使用對比,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • Mybatis 將table表名作為參數(shù)傳入操作

    Mybatis 將table表名作為參數(shù)傳入操作

    這篇文章主要介紹了Mybatis 將table表名作為參數(shù)傳入操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • Java 用反射設置對象的屬性值實例詳解

    Java 用反射設置對象的屬性值實例詳解

    這篇文章主要介紹了Java 用反射設置對象的屬性值實例詳解的相關資料,需要的朋友可以參考下
    2017-05-05
  • 通過實例解析Java不可變對象原理

    通過實例解析Java不可變對象原理

    這篇文章主要介紹了通過實例解析Java不可變對象原理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-10-10
  • Java string類型轉換成map代碼實例

    Java string類型轉換成map代碼實例

    這篇文章主要介紹了Java string類型轉換成map代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-03-03
  • Java中的Sentinel持久化規(guī)則啟動

    Java中的Sentinel持久化規(guī)則啟動

    這篇文章主要介紹了Java中的Sentinel持久化規(guī)則啟動,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08

最新評論