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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
MybatisPlus查詢條件空字符串和NULL問題背景分析
文章詳細分析了MybatisPlus在處理查詢條件時,空字符串和NULL值的問題,MP 3.3.0及以上版本提供了多種解決方法,包括在Bean屬性上使用注解、全局配置等,推薦使用全局配置的方式來解決這個問題,以避免在SQL查詢中出現(xiàn)不必要的空字符串條件,感興趣的朋友跟隨小編一起看看吧2025-03-03java.util.Random和concurrent.ThreadLocalRandom使用對比
這篇文章主要介紹了java.util.Random和concurrent.ThreadLocalRandom使用對比,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07