Mybatis-plus 代码生成器(版本:3.5.1)
Mybatis-plus代码生成器
1. 引入依赖
<!-- mysql连接 -->
<dependency>
<groupId>com.mysql</groupId>
<artifactId>mysql-connector-j</artifactId>
<scope>runtime</scope>
</dependency>
<!-- mybatis-plus依赖 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.1</version>
</dependency>
<!-- mybatis-plus代码生成 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.5.1</version>
</dependency>
<!-- 以上两个依赖版本号要一致 -->
<!-- MyBatis-Plus模板引擎 -->
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity</artifactId>
<version>1.7</version>
</dependency>
2. 修改application.yml配置文件
# 配置数据源
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/db1?useSSL=false&&characterEncoding=utf-8&&serverTimezone=Asia/Shanghai
hikari:
username: root
password: 1234
# mybatis-plus的配置
mybatis-plus:
mapper-locations: classpath*:mapper/*Mapper.xml
configuration:
# 打开mybatis运行sql的日志
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
# configuration:
# 关闭打印sql查询数据
# log-impl: org.apache.ibatis.logging.nologging.NoLoggingImpl
# 开启打印sql查询数据
# org.apache.ibatis.logging.stdout.StdOutImpl
map-underscore-to-camel-case: true
type-aliases-package: com.aaa.entity
# 逻辑删除组件
# global-config:
# db-config:
# logic-delete-field: flag # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2)
# logic-delete-value: 1 # 逻辑已删除值(默认为 1)
# logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)
3. 编写生成类
package com.aaa;
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.config.*;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
@SpringBootTest
public class GeneratorServiceEntity {
// 路径设置
public String PROJECT_DIR = "E:\\WorkSpace3\\mp-demo\\"; // 项目路径
public String PACKAGE = "com"; // 设置父包名 全名 com.aaa
public String START_PACKAGE = "aaa"; // 设置父包模块名(即启动类所在包的包名)
// 数据库设置
public String URL = "jdbc:mysql://localhost:3306/db1?serverTimezone=Asia/Shanghai";
public String USERNAME = "root";
public String PASSWORD = "1234";
// 要生产的表
public List<String> TABLES = Arrays.asList("tbl_book");
// 相对路径(无需改动)
public String JAVA_DIR = PROJECT_DIR + "src\\main\\java\\";
public String MAPPER_XML_DIR = PROJECT_DIR + "src\\main\\resources\\mapper\\";
@Test
public void contextLoads() {
FastAutoGenerator.create(URL, USERNAME, PASSWORD)
// 全局配置
.globalConfig(builder -> {
builder.author("shang") // 设置作者
// .enableSwagger() // 开启 swagger 模式
.fileOverride() // 覆盖已生成文件
// .disableOpenDir() // 不打开目录
.outputDir(JAVA_DIR); // 指定输出目录
})
// 包配置
.packageConfig(builder -> {
builder.parent(PACKAGE) // 设置父包名
.moduleName(START_PACKAGE) // 设置父包模块名
.pathInfo(Collections.singletonMap(OutputFile.mapperXml, MAPPER_XML_DIR)); // 设置mapperXml生成路径
})
// 策略配置
.strategyConfig(builder -> {
builder.addInclude(TABLES) // 设置需要生成的表名
.addTablePrefix("t_", "c_","tbl_") // 设置过滤表前缀
// Entity策略配置
.entityBuilder()
.enableLombok() // 开启 lombok 模型
// .logicDeleteColumnName("") // 逻辑删除字段名(数据库)
// .logicDeletePropertyName("") // 逻辑删除属性名(实体)
// .enableTableFieldAnnotation() // 开启生成实体时生成字段注解
// Controller策略配置
.controllerBuilder()
.enableRestStyle() // 开启生成 @RestController 控制器
// Service策略配置
.serviceBuilder()
.formatServiceFileName("%sService")
.formatServiceImplFileName("%sServiceImpl")
// Mapper策略配置
.mapperBuilder()
.enableMapperAnnotation() // 开启 @Mapper 注解
;
})
// .templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker引擎模板,默认的是Velocity引擎模板
.execute();
}
}
需要修改的地方
4. 测试:
在controller中编写一个查询所有的接口,其他的都不做改变
浏览器访问该接口
成功!