maven配置
<dependencies>
<!--通用Mapper-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus</artifactId>
<version>3.5.1</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.5.2</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.30</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.22</version>
</dependency>
</dependencies>
代码配置
package infrastructure.core.dao.generator;
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
import com.baomidou.mybatisplus.generator.config.OutputFile;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
import com.baomidou.mybatisplus.generator.fill.Column;
import java.util.Collections;
/**
* @author 作者
*/
public class Generator {
public static void main(String[] args) {
String dbUrl = "jdbc:mysql://xxxx/xxxx?useUnicode=true";
String outPut = "输出路径";
FastAutoGenerator.create(dbUrl, "root", "root")
.globalConfig(builder -> {
builder.author("baomidou") // 设置作者
// .enableSwagger() // 开启 swagger 模式
.fileOverride() // 覆盖已生成文件
.disableOpenDir() // 覆盖已生成文件
.outputDir(System.getProperty("user.dir") + outPut); // 指定输出目录
})
.packageConfig(builder -> {
builder.parent("generator") // 设置父包名
.moduleName("dao") // 设置父包模块名
.entity("entity") // pojo 实体类包名,其它包名同理
// .other("utils") // 自定义文件包名
.pathInfo(Collections.singletonMap(OutputFile.xml, System.getProperty("user.dir") + outPut + "dao/mapper")); // 设置mapperXml生成路径
})
// 策略配置
.strategyConfig(builder -> {
builder.addInclude("数据库表名称")
.entityBuilder()
.enableLombok()// 是否使用lombok注解
.enableTableFieldAnnotation()// 生成的实体类字段上是否加注解 @TableField("数据库字段名称")
// .logicDeleteColumnName("deleted") //逻辑删除字段名
.naming(NamingStrategy.underline_to_camel) //数据库表映射到实体的命名策略:下划线转驼峰命
.columnNaming(NamingStrategy.underline_to_camel) //数据库表字段映射到实体的命名策略:下划线转驼峰命
.addTableFills(
new Column("created", FieldFill.INSERT),
new Column("modified", FieldFill.INSERT_UPDATE)
) //添加表字段填充,"created"字段自动填充为插入时间,"modified"字段自动填充为插入修改时间
//通用查询结果列和通用查询映射结果
.mapperBuilder()
.enableBaseColumnList()// 是否生成<sql id="Base_Column_List">
.enableBaseResultMap()// 设置需要生成字段与实体类的映射Map <resultMap id="BaseResultMap" type="实体类全路径">
.enableMapperAnnotation() //开启 @Mapper 注解
.serviceBuilder()
; // 设置过滤表前缀
})
.templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker引擎模板,默认的是Velocity引擎模板
.execute();
}
}