服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - springboot vue项目后端列表接口分页模糊查询

springboot vue项目后端列表接口分页模糊查询

2022-12-27 20:21把苹果咬哭的测试笔记 Java教程

这篇文章主要为大家介绍了springboot vue项目后端列表接口分页模糊查询,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

基于 springboot+vue 的测试平台开发

继续更新

打开项目管理,就需要看到列表里展示项目数据,比如这样(截图是这个前端框架的demo,仅作示意):

springboot vue项目后端列表接口分页模糊查询

那么对应到我们平台的项目管理功能,就需要有:

  • 列表展示添加的项目数据
  • 可以通过项目名称查询指定的项目
  • 新增项目
  • 编辑项目
  • 其他功能...

新增项目的接口已经实现,接下来实现项目列表接口。

这个列表接口,我需要它可以同时满足分页以及条件查询,路径大概为/list/{currentPage}/{pageSize}。

其中 currentPage 表示当前是第几页,pageSize 表示每页大小。
比如/list/1/5},就说明我要查第 1 页,每页展示 5 条数据。

一、分页插件

mybatis-plus 提供了一些很实用的插件,其中就包括分页插件。

新建一个配置类 MybatisPlusConfig 用于存放 mybatis-plus 相关插件配置,并且注册分页插件:

package com.pingguo.bloomtest.config;
import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class MybatisPlusConfig {
  // 分页插件
  @Bean
  public PaginationInterceptor paginationInterceptor() {
      return new PaginationInterceptor();
  }
}

二、实现接口

实现的套路还是之前的那样,说到这,其实 mybatis-plus 还提供了代码生成器 AutoGenerator。

通过它可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码,提升开发效率。

但是这里我并不要使用,因为本来就是学习的过程,多写写加深印象。另外本工程量实在也不大,就没必要用了。

1. 编写 Service 层

在之前的 ProjectService 下,新增查询方法 getProjectList 。

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  public IPage<Project> getProjectList(int currentPage, int pageSize, Project project) {
      // 创建分页对象,current为当前页数,size为每页最大记录数
      Page<Project> pageProject = new Page<>(currentPage, pageSize);
      QueryWrapper<Project> wrapperProject = new QueryWrapper<>();
      // 第一个参数为是否执行条件,为true则执行该条件
      wrapperProject.like(StringUtils.isNoneBlank(project.getProjectName()), "projectName", project.getProjectName());
      // 调用分页查询方法,传入分页对象-pageProject,wrapperProject是构造条件对象
      return projectDAO.selectPage(pageProject, wrapperProject);
  }
  • 创建分页对象 Page,它有 2 个参数,其中 current 为当前页数,size 则为每页最大记录数。
  • 因为 getProjectList 方法也要实现条件查询,所以创建条件查询对象。
  • wrapperProject.like 使用模糊查询,like 方法可以有 3 个参数,第一个参数为是否执行条件,当
  • projectName 为空就不执行。
  • 最后调用 selectPage 方法,传入分页对象-pageProject 和 构造条件对象 wrapperProject。

返回的对象类型是 IPage,包名也贴出来了。

2. 编写 Controller 层

在之前的 ProjectController 类下新增控制方法 getProjectList 来处理请求:

@PostMapping("/list/{currentPage}/{pageSize}")
  public Result getProjectList(@PathVariable int currentPage,
                               @PathVariable int pageSize,
                               @RequestBody Project project) {
      IPage<Project> IPageProject = projectService.getProjectList(currentPage, pageSize, project);
      return Result.success(IPageProject);
  }

@PathVariable注解用来获取路径上的参数,@RequestBody用来获取请求体。

最后把返回结果 IPageProject 放到统一结果里返回return Result.success(IPageProject)。

三、测试接口

自测一下查询接口。目前 Project 表里有 14 条数据。

1. 测试分页

localhost:8080/bloomtest/project/list/2/5,14条数据按理会分为 3 页,第二页从 id=6 的数据开始,每页展示 5 条。

springboot vue项目后端列表接口分页模糊查询

继续往下,到 id=10 截止,共 5 条,结果正确。

springboot vue项目后端列表接口分页模糊查询

另外,还可以看到返回内容里还有几个字段,都是分页相关:

  • "total": 14表示共 14 条记录。
  • "size": 5表示每页最大 5 条记录。
  • "current": 2表示当前是第 2 页。
  • "pages": 3表示共 3 页。

这些字段在前端使用分页控件的时候需要用到。

2. 测试条件查询

传入查询参数:

{ "projectName": "测试项目5"}

springboot vue项目后端列表接口分页模糊查询

测试模糊查询:

{ "projectName": "6"}

springboot vue项目后端列表接口分页模糊查询

结果正确。

以上就是springboot vue项目后端列表接口分页模糊查询的详细内容,更多关于springboot vue列表分页模糊查询的资料请关注服务器之家其它相关文章!

原文链接:https://blog.csdn.net/wessonlan/article/details/124812913

延伸 · 阅读

精彩推荐