SpringBoot 中mybatis-plus的代码生成器和常用配置文件_java

配置文件内容

# 服务端口
server.port=8001

# 服务名
spring.application.name=service-edu

# 环境设置 dev test prod
spring.profiles.active=dev

#mysql 数据库连接
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/java_test?serverTimezone=GMT%2B8
spring.datasource.username=root
spring.datasource.password=

# mysql 日志
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
#配置时间格式
spring.jackson.date-format=yyyy-MM-dd HH:mm:ss
spring.jackson.time-zone=GMT+8
以下是代码生成器  放在什么位置都行 我是放在测试test文件中

package com.codeGenerator.demo;

import com.baomidou.mybatisplus.annotation.DbType;
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.rules.DateType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import org.junit.Test;

/**
 * @author
 * @since 2018/12/13
 */
public class CodeGenerator {

    @Test
    public void run() {

        // 1、创建代码生成器
        AutoGenerator mpg = new AutoGenerator();

        // 2、全局配置
        GlobalConfig gc = new GlobalConfig();
        String projectPath = System.getProperty("user.dir");
        //修改代码存放位置
        gc.setOutputDir("D:\\works\\project\\json\\java\\school\\service\\edu_service\\" + "/src/main/java");

        //作者
        gc.setAuthor("Json");
        gc.setOpen(false); //生成后是否打开资源管理器  是否生成后 打开文件
        gc.setFileOverride(false); //重新生成时文件是否覆盖

        //UserServie
        gc.setServiceName("%sService");    //去掉Service接口的首字母I

//  id 生成策略
IdType 类型:
AUTO 自动增长
ID_WORKER MP自带
ID_WORKER_STR MP自带
INPUT 自己输入
NONE  没策略
UUID 唯一值
        gc.setIdType(IdType.ID_WORKER_STR); 
        gc.setDateType(DateType.ONLY_DATE);//定义生成的实体类中日期类型
        gc.setSwagger2(true);//开启Swagger2模式

        mpg.setGlobalConfig(gc);

        // 3、数据源配置
        DataSourceConfig dsc = new DataSourceConfig();
        //修改数据库
        dsc.setUrl("jdbc:mysql://localhost:3306/java_test?serverTimezone=GMT%2B8");
        dsc.setDriverName("com.mysql.cj.jdbc.Driver");
        dsc.setUsername("root");
        //密码
        dsc.setPassword("");
        dsc.setDbType(DbType.MYSQL);
        mpg.setDataSource(dsc);

        // 4、包配置
        PackageConfig pc = new PackageConfig();
        pc.setModuleName("eduservice"); //模块名
        //包  com.school.eduservice
        pc.setParent("com.school");
        //包  com.atguigu.eduservice.controller
        pc.setController("controller");  // 控制曾
        pc.setEntity("entity");    //实体类
        pc.setService("service");  //实现类
        pc.setMapper("mapper");  // 数据库操作
        mpg.setPackageInfo(pc);

        // 5、策略配置
        StrategyConfig strategy = new StrategyConfig();

        strategy.setInclude("edu_teacher");  // 修改你要创建的表名

        strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略
        strategy.setTablePrefix(pc.getModuleName() + "_"); //生成实体时去掉表前缀

        strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略
        strategy.setEntityLombokModel(true); // lombok 模型 @Accessors(chain = true) setter链式操作

        strategy.setRestControllerStyle(true); //restful api风格控制器
        strategy.setControllerMappingHyphenStyle(true); //url中驼峰转连字符

        mpg.setStrategy(strategy);


        // 6、执行
        mpg.execute();
    }
}