package com.ruoyi;
|
|
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
|
import com.baomidou.mybatisplus.generator.config.OutputFile;
|
import com.baomidou.mybatisplus.generator.config.rules.DateType;
|
import com.baomidou.mybatisplus.generator.engine.VelocityTemplateEngine;
|
import org.junit.jupiter.api.Test;
|
import org.springframework.boot.test.context.SpringBootTest;
|
|
import java.util.Collections;
|
|
/**
|
* @Version 1.0
|
* @Author Jin_quan Ou
|
* @Date 2023-03-12 17:14
|
*/
|
|
@SpringBootTest
|
public class generatorTest {
|
@Test
|
public void test01() {
|
//创建一个代码生成器
|
FastAutoGenerator.create("jdbc:mysql://localhost:3306/ruoyi?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8",
|
"root", "123456")
|
//全局配置(GlobalConfig)
|
.globalConfig(builder -> {
|
builder.author("ojq") // 设置作者,可以写自己名字
|
//.enableSwagger() // 开启 swagger 模式,这个是接口文档生成器,如果开启的话,就还需要导入swagger依赖
|
.fileOverride() // 覆盖已生成文件
|
.dateType(DateType.TIME_PACK) //时间策略
|
.commentDate("yyyy-MM-dd") //注释日期
|
.outputDir("F:\\IDEAWorkSpace\\src\\main\\java"); // 指定输出目录,一般指定到java目录
|
})
|
//包配置(PackageConfig)
|
.packageConfig(builder -> {
|
builder.parent("com.ojq") // 设置父包名
|
.moduleName("") // 设置父包模块名,这里一般不设置
|
.pathInfo(Collections.singletonMap(OutputFile.mapperXml, "F:\\IDEAWorkSpace\\src\\main\\resources\\com\\ojq\\mapper")); // 设置mapperXml生成路径,这里是Mapper配置文件的路径,建议使用绝对路径
|
})
|
//策略配置(StrategyConfig)
|
.strategyConfig(builder -> {
|
// builder.addInclude("zf_clean") // 设置需要生成的表名
|
// .addInclude("zf_collection") // 设置需要生成的表名
|
builder.addInclude("z_abroad") // 设置需要生成的表名
|
.addInclude("z_autobiography") // 设置需要生成的表名
|
.addInclude("z_certificate") // 设置需要生成的表名
|
.addInclude("z_child") // 设置需要生成的表名
|
.addInclude("z_dict") // 设置需要生成的表名
|
.addInclude("z_experience") // 设置需要生成的表名
|
.addInclude("z_health_base") // 设置需要生成的表名
|
.addInclude("z_health_habit") // 设置需要生成的表名
|
.addInclude("z_health_info") // 设置需要生成的表名
|
.addInclude("z_honor") // 设置需要生成的表名
|
.addInclude("z_idea") // 设置需要生成的表名
|
.addInclude("z_info_user") // 设置需要生成的表名
|
.addInclude("z_login_user") // 设置需要生成的表名
|
.addInclude("z_marry") // 设置需要生成的表名
|
.addInclude("z_property") // 设置需要生成的表名
|
.addInclude("z_secret") // 设置需要生成的表名
|
.addInclude("z_self_note") // 设置需要生成的表名
|
.addInclude("z_stay_out") // 设置需要生成的表名
|
.addInclude("z_travel_base") // 设置需要生成的表名
|
.addInclude("z_travel_price") // 设置需要生成的表名
|
.addInclude("z_year_health") // 设置需要生成的表名
|
.addInclude("z_year_info"); // 设置需要生成的表名
|
|
|
builder.serviceBuilder()
|
.formatServiceFileName("%sService") //设置service的命名策略,没有这个配置的话,生成的service和serviceImpl类前面会有一个I,比如IUserService和IUserServiceImpl
|
.formatServiceImplFileName("%sServiceImpl"); //设置serviceImpl的命名策略
|
builder.controllerBuilder()
|
.enableRestStyle(); // 开启生成@RestController 控制器,不配置这个默认是Controller注解,RestController是返回Json字符串的,多用于前后端分离项目。
|
builder.mapperBuilder()
|
.enableMapperAnnotation() ;//开启 @Mapper 注解,也就是在dao接口上添加一个@Mapper注解,这个注解的作用是开启注解模式,就可以在接口的抽象方法上面直接使用@Select和@Insert和@Update和@Delete注解。
|
})
|
// .templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker引擎模板,默认的是Velocity引擎模板
|
.templateEngine(new VelocityTemplateEngine())
|
.execute(); //执行以上配置
|
}
|
|
}
|