Mybatis逆向工程是使用mybaits提供的插件,根据数据表结构生成对应的Xx.java(pojo)、XxMapper.xml、XxMapper.java、XxService.java、XxServiceImpl.java、XxController.java等。减少重复的板砖工作。
1.添加依赖包
<!-- mysql db -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!--代码生成器-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.5.1</version>
</dependency>
2.生成代码工具类
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.config.OutputFile;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class CodeGenerator {
/**
* 数据库链接地址
**/
private static final String JDBC_URL_MAN = "jdbc:mysql://101.200.75.180:3306/xfdp?useUnicode=true&characterEncoding=UTF-8";
/**
* 数据库登录账号
**/
private static final String JDBC_USER_NAME = "xxx";
/**
* 数据库登录密码
**/
private static final String JDBC_PASSWORD = "XXX";
public static void main(String[] args) {
String dir = "\\xx\\xx"; // 生成代码的路径 根路径上可以配置""
String tablePrefix = "t_"; // 表前缀(t_、xx_等等根据实际情况配置)
List<String> tables = new ArrayList<>(); // 逆向生成表容器
tables.add("t_doctor");
FastAutoGenerator.create(JDBC_URL_MAN, JDBC_USER_NAME, JDBC_PASSWORD)
.globalConfig(builder -> {
builder.author("ocean") // 作者
.outputDir(System.getProperty("user.dir") + dir + "\\src\\main\\java") // 输出路径(写到java目录)
.enableSwagger() // 开启swagger
.commentDate("yyyy-MM-dd")
.fileOverride(); // 开启覆盖之前生成的文件
})
.packageConfig(builder -> {
builder.parent("com.cx") // 根包名称
.moduleName("health") // 业务包名称
.entity("entity") // 实体包名称
.service("service") // 业务层包名称
.serviceImpl("serviceImpl") // 业务层实现类包名称
.controller("controller") // 控制层包名称
.mapper("mapper") // 持久层包名称
.xml("mapper") // 持久层包名称
.pathInfo(Collections.singletonMap(OutputFile.mapperXml, System.getProperty("user.dir") + dir + "\\src\\main\\resources\\mapper"));
})
.strategyConfig(builder -> {
builder.addInclude(tables)
.addTablePrefix(tablePrefix)
.serviceBuilder()
.formatServiceFileName("%sService")
.formatServiceImplFileName("%sServiceImpl")
.entityBuilder()
.enableLombok()
.logicDeleteColumnName("deleted")
.enableTableFieldAnnotation()
.controllerBuilder()
.formatFileName("%sController")
.enableRestStyle()
.mapperBuilder()
.enableBaseResultMap() // 生成通用的resultMap
.superClass(BaseMapper.class)
.formatMapperFileName("%sMapper")
.enableMapperAnnotation()
.formatXmlFileName("%sMapper");
})
//.templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker引擎模板,默认的是Velocity引擎模板
.execute();
}
}