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

首先生成entity,mapper,xml以及tableDef.看一下项目路径
在这里插入图片描述
生成器的代码

package com.zq.mybatis.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-mybatis";//项目名称
        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+"."+mk);

        //设置只生成哪些表
        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

        //设置生成 entity 并启用 Lombok
        globalConfig.setEntityGenerateEnable(true);
        globalConfig.setEntityWithLombok(true);
        globalConfig.setEntityOverwriteEnable(true);

        //设置生成 mapper
        globalConfig.setMapperGenerateEnable(true);

        //设置xml
        globalConfig.setMapperXmlPath(projectPath.concat("/src/main/resources/mapper/"+mk+"/"));
        globalConfig.setMapperXmlGenerateEnable(true);

        //设置def
        globalConfig.setTableDefGenerateEnable(true);

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

        // impl
        //globalConfig.setServiceImplGenerateEnable(true);

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


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

        return globalConfig;
    }
}

必要的生成器依赖pom

        <!--flex生成代码-->
        <dependency>
            <groupId>com.mybatis-flex</groupId>
            <artifactId>mybatis-flex-codegen</artifactId>
            <version>1.5.5</version>
        </dependency>
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.8.11</version>
        </dependency>
        <dependency>
            <groupId>com.zaxxer</groupId>
            <artifactId>HikariCP</artifactId>
            <version>3.4.5</version>
        </dependency>

可能用到的依赖

        <!--mysql-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.26</version>
        </dependency>
        <dependency>
            <groupId>com.mysql</groupId>
            <artifactId>mysql-connector-j</artifactId>
            <scope>runtime</scope>
            <version>8.0.31</version>
        </dependency>

application.properties

//使用application-sys.properties配置  sys配置文件就是代码生成器专属的配置
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.mybatis
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值