Mybatis-Plus代码生成器
代码生成器介绍
代码生成器顾名思义就是为我们生成一些代码,省去了我们一些时间。
AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码。
极大的提升了开发效率,MyBatis-Plus从3.0.3 之后移除了代码生成器与模板引擎的默认依赖,需要手动添加相关依赖,才能实现代码生成器功能。
操作流程
1、构建maven工程引入相关依赖
<!-- 数据库mysql驱动 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
<!-- mybatis-plus 的场景启动器-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.0</version>
</dependency>
<!-- mybatis-plus 代码生成器包-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.4.1</version>
</dependency>
<!-- 代码生成器需要的模板依赖-->
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity-engine-core</artifactId>
<version>2.3</version>
</dependency>
2、GlobalConfig全局配置编码
@SpringBootTest
class SpringbootMybatisPlusGeneratorApplicationTests {
@Test
void contextLoads() {
// 代码生成器
AutoGenerator mpg = new AutoGenerator();
// ====== 全局配置 ======
GlobalConfig gc = new GlobalConfig();
// 工程所在路径
String projectPath = System.getProperty("user.dir");
// 指定代码在指定的目录中生成
gc.setOutputDir(projectPath + "/src/main/java");
// 作者名称
gc.setAuthor("chenshuang");
// 设置生成的日期只为date格式
gc.setDateType(DateType.ONLY_DATE);
// 默认工具栏文件夹是否打开
gc.setOpen(false);
// gc.setSwagger2(true); 实体属性 Swagger2 注解
mpg.setGlobalConfig(gc);
// ====== 数据源配置 ======
DataSourceConfig dsc = new DataSourceConfig();
dsc.setUrl("jdbc:mysql:///mybatisplus?useUnicode=true&useSSL=false&characterEncoding=utf8");
// dsc.setSchemaName("public");
dsc.setDriverName("com.mysql.jdbc.Driver");
dsc.setUsername("root");
dsc.setPassword("123456");
mpg.setDataSource(dsc);
// ====== 包的配置 ======
PackageConfig pc = new PackageConfig();
pc.setParent("com.chenshuang");
pc.setEntity("entity");
pc.setMapper("mapper");
pc.setController("controller");
pc.setServiceImpl("service.xml");
mpg.setPackageInfo(pc);
// ====== 模板的配置 ======
TemplateConfig templateConfig = new TemplateConfig();
// 默认关闭不需要的生成内容
// templateConfig.setXml(null);
templateConfig.setService(null);
templateConfig.setServiceImpl(null);
mpg.setTemplate(templateConfig);
// ====== 策略配置 ======
StrategyConfig strategy = new StrategyConfig();
// 数据库表映射到实体的命名策略 【表名】
strategy.setNaming(NamingStrategy.underline_to_camel);
// 数据库表字段映射到实体的命名策略 【列名】【e_id---eId】
strategy.setColumnNaming(NamingStrategy.underline_to_camel);
strategy.setSuperEntityClass("com.baomidou.mybatisplus.extension.activerecord.Model");
strategy.setEntityLombokModel(true);
strategy.setRestControllerStyle(true);
// 写数据库中要映射的表名 用逗号分隔
String tableNames="user";
strategy.setInclude(tableNames.split(","));
strategy.setControllerMappingHyphenStyle(true);
mpg.setStrategy(strategy);
// ====== 执行代码生成器 ======
mpg.execute();
}
}
3、配置
3、执行生成器代码完成测试
在主启动类上用@MapperScan扫描mapper接口 @MapperScan("com.offcn.ssm.mapper") 在application.yml中添加数据库配置信息 spring: datasource: driver-class-name: com.mysql.jdbc.Driver url: jdbc:mysql:///mybatis_plus username: root password: root logging: level: com: offcn: mybatis: dao: debug 在生成的contorller中编写查询方法 @RestController @RequestMapping("/tb-employee") public class TbEmployeeController { @Autowired private TbEmployeeService tbEmployeeService; @RequestMapping("/emps") public List<TbEmployee> getEmployees(){ List<TbEmployee> list = tbEmployeeService.list(); return list; } }
访问:http://localhost:8080/user/getuser