CodeGenerator代码生成器

CodeGenerator代码生成器

第一步:引入依赖

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.0.5</version>
</dependency>

第二部:创建CodeGenerator.java类

package com.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:Kun
 * Copyright:1.0
 * Date:2020/12/26 10:09
 * Description: 逆向工程生成代码
 */
public class CodeGenerator {

    @Test
    public void run() {

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

        // 2、全局配置
        GlobalConfig gc = new GlobalConfig();
        String projectPath = System.getProperty("user.dir");

        //设置代码的绝对路径:F:\Java文档\IDEA\parent\service\service_edu  建议打开文档目录复制路径
        gc.setOutputDir("F:\\Java文档\\IDEA\\parent\\service\\service_edu" + "/src/main/java");

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

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

        //对应表的主键策略:数字:ID_WORKER  字符串:ID_WORKER_STR
        gc.setIdType(IdType.ID_WORKER);     
        
        //定义生成的实体类中日期类型:数据库是datetime java中是date
        gc.setDateType(DateType.ONLY_DATE);    
        
        gc.setSwagger2(true);                   //开启Swagger2模式

        mpg.setGlobalConfig(gc);

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

        // 4、包配置
        PackageConfig pc = new PackageConfig();

        //com.atguigu.eduservice
        pc.setModuleName("eduservice"); //模块名
        //包  com.lkz
        pc.setParent("com.lkz");
        //子包  com.lkz.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_chapter","edu_course");         //可添加多张表逗号分割 ,

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

        //数据库表字段映射到实体的命名策略
        strategy.setColumnNaming(NamingStrategy.underline_to_camel);    
        
        // lombok 模型 @Accessors(chain = true) setter链式操作
        strategy.setEntityLombokModel(true); 
        
        strategy.setRestControllerStyle(true);          //restful api风格控制器
        strategy.setControllerMappingHyphenStyle(true); //url中驼峰转连字符

        mpg.setStrategy(strategy);

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

第三步:修改配置并执行代码

1.设置代码的绝对路径(建议打开文档目录复制路径)
2.对应表的主键策略:数字:ID_WORKER  字符串:ID_WORKER_STR
3.数据源配置
4.包配置
5.修改要生成的表(可添加多张表逗号分割 ,)
end

评论