Mybatis-Plus 生成代码的方式分两种,通过3.5.1版本区分新和旧,这里以3.5.3.1版本为例,使用新的代码生成器方式生成。
参考官网:代码生成器(新)
具体步骤如下:
1、导入依赖
<!-- https://mvnrepository.com/artifact/com.baomidou/mybatis-plus-boot-starter -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.3.1</version>
</dependency>
<!-- 代码生成器 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.5.3.1</version>
</dependency>
<!-- mysql驱动 -->
<dependency>
<groupId>com.mysql</groupId>
<artifactId>mysql-connector-j</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
2、创建生成器类
创建代码生成器类
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
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 org.apache.ibatis.annotations.Mapper;
import java.util.ArrayList;
import java.util.Collections;
/**
* mybatis-plus 代码生成器
*
* @author Feiz.Zheng
*/
public class GeneratorCode {
public static void main(String[] args) {
String projectPath = System.getProperty("user.dir"); // 获取项目路径
String path = projectPath + "\\src\\main\\java";
String url = "jdbc:mysql://127.0.0.1:3306/xxxx?useSSL=false&useUnicode=true&serverTimeZone=GMT%2b8"; //数据库url
String username = "xxx"; //用户名
String password = "xxx"; // 密码
ArrayList<String> tables = new ArrayList<>(); // 需要生成代码的表有哪些
tables.add("integration_user");
FastAutoGenerator.create(url, username, password)
.globalConfig(builder -> {
builder.author("mntalk") // 设置author
.enableSwagger() // 添加Swagger注解
.fileOverride()
.outputDir(path); //设置路径
})
.packageConfig(builder -> {
builder.parent("com.xxx.integration") // 包路径,改成自己的
.entity("entity") // 实体包名
.service("service") // service包名
.serviceImpl("service.impl") // service实现类包名
.xml("mapper") // dao层包名
.controller("controller") // controller包名
.pathInfo(Collections.singletonMap(OutputFile.xml, projectPath + "\\src\\main\\resources\\mapper")); // xml映射文件包名
})
.strategyConfig(builder -> {
builder.addInclude(tables)
.addTablePrefix("integration_") // 表前缀
.serviceBuilder() // 构建service
.formatServiceFileName("%sService") // service命名规则
.formatServiceImplFileName("%sServiceImpl") //service实现类命名规则
.controllerBuilder() // 构建controller
.formatFileName("%sController") // controller命名规则
.enableRestStyle() //驼峰命名
.entityBuilder() //构建实体类
.enableChainModel()
.idType(IdType.AUTO) //id类型
.enableLombok() //lombok
.naming(NamingStrategy.underline_to_camel) // 数据库下划线转为驼峰式命名
.logicDeleteColumnName("deleted") // 逻辑删除字段
.versionColumnName("version") // 乐观锁
.addTableFills(new Column("gmt_create", FieldFill.INSERT)) // 新增时填充
.addTableFills(new Column("gmt_modified", FieldFill.INSERT_UPDATE)) // 新增或修改时填充
.enableTableFieldAnnotation()
.mapperBuilder() // 构建dao层
.enableBaseResultMap() // 通用map
.superClass(BaseMapper.class) // 继承 BaseMapper
.formatMapperFileName("%sMapper") // dao层命名规则
.formatXmlFileName("%sMapper") // xml映射文件命名规则
.mapperAnnotation(Mapper.class); // dao层添加@Mapper注解
})
.templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker模板引擎
.execute();
}
}
代码都加了注释的,很容易理解。数据库地址、用户名和密码换成自己的就行,有哪些表需要生成代码。添加到 tables 容器里面就行。
运行代码之后,项目结构如下所示:
这样就行了,之后其他配置请参考官网或者评论留言。
求一键三连:点赞、分享、收藏
点赞对我真的非常重要!在线求赞,加个关注我会非常感激!@小郑聊编程