关于使用MybatisPlus一些注意事项

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 page=new Page<>();
        page.setCurrent(pageBean.getPage());//设置页码
        page.setSize(pageBean.getRows());//设置每页显示的条数

        QueryWrapper wrapper = new QueryWrapper<>();
        //根据书本名称模糊查询
        if(StringUtils.isNotBlank(book.getBookName())){
            wrapper.like("book_name",book.getBookName());
        }
        Page page1 = bookService.page(page,wrapper);
        return new JsonResponseBody(page1.getRecords(), (int) page1.getTotal());
    }

以后再遇到坑了补上

你可能感兴趣的:(java,开发语言,后端)