1.关于生成代码路径的坑
// 全局配置
GlobalConfig gc = new GlobalConfig();
String projectPath = System.getProperty("user.dir");
gc.setOutputDir(projectPath + "/src/main/java");
gc.setAuthor("zking");
gc.setOpen(false);
// gc.setSwagger2(true); 实体属性 Swagger2 注解
mpg.setGlobalConfig(gc);
gc.setBaseResultMap(true); //resultMap
gc.setBaseColumnList(true); //ColumnList
上面代码中的变量projectPath就是你生成代码的路径,注意创项目时别弄错了,出了问题可以使用debug查看路径是否正确
2.关于分页
新版和旧版是不兼容的,这点官网有说明,我使用是旧版
创建分页工具类
@Configuration
@MapperScan("com.baomidou.cloud.service.*.mapper*")
public class MybatisPlusConfig {
// 旧版
@Bean
public PaginationInterceptor paginationInterceptor() {
PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
// 设置请求的页面大于最大页后操作, true调回到首页,false 继续请求 默认false
// paginationInterceptor.setOverflow(false);
// 设置最大单页限制数量,默认 500 条,-1 不受限制
// paginationInterceptor.setLimit(500);
// 开启 count 的 join 优化,只针对部分 left join
paginationInterceptor.setCountSqlParser(new JsqlParserCountOptimize(true));
return paginationInterceptor;
}
}
Controller层代码
@RequestMapping("/queryBookPager")
public JsonResponseBody<?> queryBookPager(TBook book, HttpServletRequest request){
PageBean pageBean=new PageBean();
Page<TBook> page=new Page<>();
page.setCurrent(pageBean.getPage());//设置页码
page.setSize(pageBean.getRows());//设置每页显示的条数
QueryWrapper<TBook> wrapper = new QueryWrapper<>();
//根据书本名称模糊查询
if(StringUtils.isNotBlank(book.getBookName())){
wrapper.like("book_name",book.getBookName());
}
Page<TBook> page1 = bookService.page(page,wrapper);
return new JsonResponseBody(page1.getRecords(), (int) page1.getTotal());
}
以后再遇到坑了补上