Java后端使用MyBatis-Plus添加分页拦截器
1. 添加分页插件
复制代码到common文件夹下:
代码:
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class MybatisPlusConfig {
/**
* 添加分页插件
*/
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
return interceptor;
}
}
2. 配置测试
在controller包下配置,本文以UserController文件为例:
代码:
package com.wms.controller;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.wms.common.QueryPageParam;
import com.wms.entity.User;
import com.wms.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import java.util.HashMap;
import java.util.List;
@RestController
@RequestMapping("/user")
public class UserController {
@Autowired
private UserService userService;
@GetMapping("/list")
public List<User> list(){
return userService.list();
}
@PostMapping("/listPage")
public List<User> listPage(@RequestBody QueryPageParam query){
HashMap args = query.getArgs();
String name = (String)args.get("name");
Page<User> page = new Page();
page.setCurrent(query.getPageNum()); //设置当前页,默认为1
page.setSize(query.getPageSize()); //设置当前页数量,默认为10
LambdaQueryWrapper<User> lambdaQueryWrapper = new LambdaQueryWrapper();
lambdaQueryWrapper.like(User::getName,name); //模糊查询名称
IPage result = userService.page(page,lambdaQueryWrapper);
return result.getRecords();
}
}
3. 测试结果
用Postman测试,将数据库数据查询出来,成功返回数据: