pom文件
org.mybatis.spring.boot mybatis-spring-boot-starter 2.2.0 com.baomidou mybatis-plus-boot-starter 3.4.2 com.baomidou mybatis-plus-generator 3.3.2 org.apache.velocity velocity-engine-core 2.0 p6spy p6spy 3.9.1 mysql mysql-connector-java runtime org.projectlombok lombok true org.springframework.boot spring-boot-starter-test test io.springfox springfox-swagger2 2.2.2 io.springfox springfox-swagger-ui 2.2.2
创建代码自动生成器类
public static void main(String[] args) {
//构建代码自动生成器对象
AutoGenerator mpg = new AutoGenerator();
//配置策略
GlobalConfig gc = new GlobalConfig(); //全局配置
String property = System.getProperty("user.dir");
gc.setOutputDir(property+"/src/main/java");//指定输出目录
gc.setAuthor("xh");//设置作者
gc.setOpen(false);
gc.setFileOverride(true);//是否覆盖
gc.setServiceName("I%sService");//设置service接口名称 如IUserService
gc.setIdType(IdType.AUTO);//设置主键类型
gc.setDateType(DateType.ONLY_DATE);//设置时间策略
gc.setSwagger2(true);//设置swagger
mpg.setGlobalConfig(gc);
//设置数据源
DataSourceConfig dsc = new DataSourceConfig();
dsc.setUrl("jdbc:p6spy:mysql://localhost:3306/mp?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC");
dsc.setDriverName("com.p6spy.engine.spy.P6SpyDriver");
dsc.setUsername("root");
dsc.setPassword("123456");
dsc.setDbType(DbType.MYSQL);//数据库类型
mpg.setDataSource(dsc);
//包名的配置
PackageConfig pc = new PackageConfig();
pc.setModuleName("demo");
pc.setParent("com.xh");//com.xh.demo
pc.setEntity("entity");
pc.setController("controller");
pc.setMapper("mapper");
pc.setService("service");
mpg.setPackageInfo(pc);
//策略配置
StrategyConfig strategyConfig = new StrategyConfig();
strategyConfig.setInclude("user");//设置要映射的表名
strategyConfig.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略 默认下划线转驼峰命名
strategyConfig.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略
strategyConfig.setEntityLombokModel(true);//生成lombok
strategyConfig.setRestControllerStyle(true);//生成controller层 的RestController
strategyConfig.setLogicDeleteFieldName("del");//设置逻辑删除
//自动填充配置
TableFill createTime = new TableFill("create_time", FieldFill.INSERT);//设置自动填充功能
TableFill updateTime = new TableFill("update_time", FieldFill.INSERT_UPDATE);
ArrayList tableFills = new ArrayList<>();
tableFills.add(createTime);
tableFills.add(updateTime);
strategyConfig.setTableFillList(tableFills);
strategyConfig.setVersionFieldName("version"); //设置乐观锁 0未删除 1删除
strategyConfig.setControllerMappingHyphenStyle(true);
mpg.setStrategy(strategyConfig);
mpg.execute();//执行
}
MySql表
del为逻辑删除字段,0未删除,1删除
新增时create_time自动填充update_time是当前时间
修改时create_time不变update_time是自动填充



