使用的是旧代码生成器-3.4.1
依赖包
<!--生成器依赖包-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.4.1</version>
</dependency>
<!--数据库连接依赖包-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!--模板依赖-->
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity-engine-core</artifactId>
<version>2.0</version>
</dependency>
<!--lombok-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
代码
package com.lzw.generator;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
import com.baomidou.mybatisplus.generator.config.GlobalConfig;
import com.baomidou.mybatisplus.generator.config.PackageConfig;
import com.baomidou.mybatisplus.generator.config.StrategyConfig;
import com.baomidou.mybatisplus.generator.config.po.TableFill;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import java.util.ArrayList;
/**
* @Author lzw
* @Date 2022/9/9 - 09 - 09 - 14:08
*/
public class GeneratorCode {
public static void main(String[] args) {
// 代码生成器
AutoGenerator mpg = new AutoGenerator();
// 全局配置
GlobalConfig gc = new GlobalConfig();
// 设置项目目录
String projectPath = "D:\\java_project\\study_space\\dongbao\\dongbao-mall\\dongbao-study\\dongbao-service\\dongbao-ums\\src\\main\\java";
// 设置代码输出目录
gc.setOutputDir(projectPath);
// 设置作者
gc.setAuthor("lzw");
// 打开目录
gc.setOpen(false);
// 是否覆盖
gc.setFileOverride(true);
// 去Service的I前缀
gc.setServiceName("%sService");
gc.setIdType(IdType.ID_WORKER);
gc.setDateType(DateType.ONLY_DATE);
gc.setSwagger2(false);
// 将全局配置设置到代码生成器中
mpg.setGlobalConfig(gc);
// 设置数据源
DataSourceConfig dsc = new DataSourceConfig();
dsc.setDriverName("com.mysql.cj.jdbc.Driver");
dsc.setUrl("jdbc:mysql://192.168.19.66:3306/dongbao?useSSL=false&useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai");
dsc.setUsername("root");
dsc.setPassword("root");
dsc.setDbType(DbType.MYSQL);
// 将数据源设置到代码生成器中
mpg.setDataSource(dsc);
//包设置
PackageConfig pc = new PackageConfig();
pc.setParent("com.lzw");
pc.setEntity("entity");
pc.setMapper("mapper");
pc.setController("controller");
// 将包设置设置到代码生成器中
mpg.setPackageInfo(pc);
// 策略设置
StrategyConfig strategyConfig = new StrategyConfig();
// 括号中可以添加表名,不添加代表连接库中所有
strategyConfig.setInclude();
// 表下划线转驼峰
strategyConfig.setNaming(NamingStrategy.underline_to_camel);
// 列下划线转驼峰
strategyConfig.setColumnNaming(NamingStrategy.underline_to_camel);
// lombok 开启
strategyConfig.setEntityLombokModel(true);
// 设置逻辑删除的字段名
strategyConfig.setLogicDeleteFieldName("deleted");
// 自动填充
TableFill gmtCreate = new TableFill("gmt_create", FieldFill.INSERT);
TableFill gmtModify = new TableFill("gmt_modified", FieldFill.INSERT_UPDATE);
ArrayList<TableFill> tableFills = new ArrayList<>();
tableFills.add(gmtCreate);
tableFills.add(gmtModify);
strategyConfig.setTableFillList(tableFills);
//乐观锁
strategyConfig.setVersionFieldName("version");
//restcontroller
strategyConfig.setRestControllerStyle(true);
strategyConfig.setControllerMappingHyphenStyle(true);
mpg.setStrategy(strategyConfig);
mpg.execute();
}
}