【模式二】springcloud项目中使用mybatisFlex代码生成器2

springcloud项目中使用MybatisFlex代码生成器生成controller,service,impl
【模式二】springcloud项目中使用mybatisFlex代码生成器2_第1张图片
代码生成器启动类

package com.zq.zqsys.generator;

import cn.hutool.setting.dialect.Props;
import com.mybatisflex.codegen.Generator;
import com.mybatisflex.codegen.config.GlobalConfig;
import com.mybatisflex.codegen.dialect.JdbcTypeMapping;
import com.zaxxer.hikari.HikariDataSource;

import java.time.LocalDateTime;
import java.util.Date;

public class GeneratorNew {

    public static void main(String[] args) {
        String xmName = "/zq-sys";//项目名称 唯一需要在这个类配置的
        String projectPath = System.getProperty("user.dir") + "/" + xmName;//项目打开的时候 根路径
        //获取配置文件的内容
        Props props = new Props(projectPath + "/src/main/resources/application.properties");
        String active = props.getStr("spring.profiles.active");
        Props application = new Props(projectPath + "/src/main/resources/application-" + active + ".properties");
        String dataSourceName = application.getStr("spring.datasource.username");
        String dataSourcePassword = application.getStr("spring.datasource.password");
        String dataSourceUrl = application.getStr("spring.datasource.url");
        //获取该配置文件自定义信息
        String mk = application.getStr("zdy.mk");//模块名称
        String tab = application.getStr("zdy.tables");//表名
        String auth = application.getStr("zdy.author");//作者名称
        String basePackage = application.getStr("zdy.basepackage");//第一个位置根路径

        //配置数据源
        HikariDataSource dataSource = new HikariDataSource();
        dataSource.setJdbcUrl(dataSourceUrl);//+"&useInformationSchema=true"
        dataSource.setUsername(dataSourceName);
        dataSource.setPassword(dataSourcePassword);

        //创建配置内容,两种风格都可以。
        GlobalConfig globalConfig = createGlobalConfigUseStyle1(projectPath, mk, tab, auth, basePackage);

        //通过 datasource 和 globalConfig 创建代码生成器
        Generator generator = new Generator(dataSource, globalConfig);
        //生成代码
        generator.generate();
    }

    public static GlobalConfig createGlobalConfigUseStyle1(String projectPath, String mk, String tab, String auth, String basePackage) {

        //需要生成的表
        String[] tables = tab.split(",");
        //创建配置内容
        GlobalConfig globalConfig = new GlobalConfig();

        //设置根目录
        globalConfig.setSourceDir(projectPath + "/src/main/java");

        //设置根包
        globalConfig.setBasePackage(basePackage);

        //设置只生成哪些表
        globalConfig.setGenerateTable(tables);

        //设置实体类的包路径 在自动生成的service中找实体类路径的时候,import com.zq.mybatis.sys.entity;否则不设置会异常
        globalConfig.setEntityPackage("com.zq.mybatis." + mk + ".entity");
        globalConfig.setMapperPackage("com.zq.mybatis." + mk + ".mapper");//import 是根据这个路径找到该mapper

        //设置service
        globalConfig.setServiceGenerateEnable(true);

        // impl
        globalConfig.setServiceImplGenerateEnable(true);

        //设置controller
        globalConfig.setControllerGenerateEnable(true);


        //可以单独配置某个列
        JdbcTypeMapping.registerMapping(LocalDateTime.class, Date.class);
        globalConfig.getJavadocConfig().setAuthor(auth);//作者名字 可以随便起名

        return globalConfig;
    }
}

application.properties

# 没用 这是定义个端口号
server.port= 9010
# 使用代码生成器专属的自定义配置文件 application-sys.properties
spring.profiles.active= sys

application-sys.properties

#数据源
spring.datasource.url= jdbc:mysql://127.0.0.1:3306/one_piece_sys
spring.datasource.username= root
spring.datasource.password= 123456
#自定义代码生成器内容  mk模块名称 tables表名,分割 author作者名称 basepackage包路径
zdy.mk= sys
zdy.tables= sys_user,sys_auth,sys_role,sys_role_auth,sys_user_role
zdy.author= admin
zdy.basepackage= com.zq.zqsys

你可能感兴趣的:(自己搭的架构之路,spring,cloud,java,数据库)