目录
🧂1.添加mybatisPlus依赖
🥓2.添加配置类
🌭3.添加分页接口
🍿4. 添加实现类
🥞5.测试
1.添加mybatisPlus依赖
<!--mybatisPlus-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
</dependency>
2.添加配置类
- 1.将其类标志位配置类
- 2.创建MybatisPlusPageConfiguration对象,使用@Bean注解
- 3.创建mybatisPlus拦截器对象并创建分页拦截器PageinationInnerInterceptor并将其添加
- 4.返回创建好的对象
/**
* 分页插件
*/
@Configuration
public class MybatisPlusPageConfiguration {
/**
* 分页插件配置
* @return
*/
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor(){
//新建mybatisPlus拦截器
MybatisPlusInterceptor mybatisPlusInterceptor=new MybatisPlusInterceptor();
//新建分页拦截器,并将其传递给mybatisPlus拦截器
mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor());
//返回对象
return mybatisPlusInterceptor;
}
}
3.添加分页接口
1.创建分页接口,返回包装类
2.使用@RequestParm接收前端传递过来的当前页码和当前页显示的条数
3.调用service层,并将参数传递过去
@Autowired
private CouponService couponService;
@ApiOperation("分页查询优惠卷")
@GetMapping("/page_coupon")
public JsonData pageCouponList(
@ApiParam(value = "当前页")
@RequestParam(value = "page", defaultValue = "1") int page,
@ApiParam(value = "每页显示多少条")
@RequestParam(value = "size", defaultValue = "10") int size) {
Map<String, Object> pageMap = couponService.pageCouponActive(page, size);
return JsonData.buildSuccess(pageMap);
}
4. 添加实现类
1.根据controller传递过来的page,size;创建Page对象
2.根据条件分页查询数据库,获取分页全部信息
3.对分页信息进行map包装
4.为避免dao层暴露,使用BeanUtils拷贝对象到Vo层
5.返回包装后的map集合
/**
* 分页查询
*
* @param page :当前页的页码
* @param size :每页显示多少条
* @return
*/
@Override
public Map<String, Object> pageCouponActive(int page, int size) {
Page<CouponDO> pageInfo = new Page<>(page, size);
IPage<CouponDO> couponDOIPage = couponMapper.selectPage(pageInfo, new QueryWrapper<CouponDO>()
.eq("publish", CouponPublishEnum.PUBLISH)
.eq("category", CouponCategoryEnum.PROMOTION)
.orderByDesc("create_time"));
HashMap<String, Object> pageMap = new HashMap<>(3);
//总条数
pageMap.put("total_record", couponDOIPage.getTotal());
//总页数
pageMap.put("total_page", couponDOIPage.getPages());
//内容
pageMap.put("current_data", couponDOIPage.getRecords().stream().map(obj -> beanProcess(obj)).collect(Collectors.toList()));
return pageMap;
}
/**
* 将couponDo转化为couponVo
*
* @param couponDO
* @return
*/
private Object beanProcess(CouponDO couponDO) {
CouponVo couponVo = new CouponVo();
BeanUtils.copyProperties(couponDO, couponVo);
return couponVo;
}
5.测试
根据请求,postman测试~