SpringBoot2.X +Mybatis-Plus 3.X 代码生成器

SpringBoot2.X +Mybatis-Plus 3.X 代码生成器

适合MP3.0版本 使用

Pom 文件

 <!--Mybatis Plus-->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-generate</artifactId>
    <version>2.2.0</version>
</dependency>
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-generator</artifactId>
    <version>3.1.2</version>
</dependency>
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.1.2</version>
</dependency>
<dependency>
    <groupId>org.apache.velocity</groupId>
    <artifactId>velocity-engine-core</artifactId>
    <version>2.1</version>
</dependency>

**采坑: 没有 mybatis-plus-generate -2.2.0这个包 代码生成器需要引入这个包的IDType 和DbType **

复制到项目即可使用

package com.hassdata;



import com.baomidou.mybatisplus.enums.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.DbType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;


/**
 * @author WangShuai
 * @create  2019-08-23
 *
 *
 *
 */
public class GeneratorMP {

   
    public static void main(String[] args) {
      
        String packageName = "com.hassdata";   // 生成的包名
        boolean serviceNameStartWithI = false;//user -> UserService, 设置成true: user -> IUserService

        String dir = "D:\\Product\\market_for_mysql\\src\\main\\java";

        //  tablenames  是需要生成的数据库名称
        // 默认是全部表  如果需要生成个别张表,  可以打开56行的注释并注释掉57行
        generateByTables(serviceNameStartWithI,
                packageName,
                dir, ""
        );
    }
    private static void generateByTables(boolean serviceNameStartWithI, String packageName, String dir, String... tableNames ) {
     
        GlobalConfig config = new GlobalConfig();
        //mysql
        String dbUrl = "jdbc:mysql://127.0.0.1:3306/market?serverTimezone=CTT&useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true";
        DataSourceConfig dataSourceConfig = new DataSourceConfig();
        dataSourceConfig.setDbType(DbType.MYSQL)
                .setUrl(dbUrl)
                .setUsername("root")
                .setPassword("root")
                .setDriverName("com.mysql.jdbc.Driver");

        // 策略配置
        StrategyConfig strategyConfig = new StrategyConfig();
      
       // strategyConfig.setInclude(tableNames);
        strategyConfig.setExclude(null);
        strategyConfig
                .setCapitalMode(false)   // 全局大写命名
                .setEntityLombokModel(true)   // Lomnok
              // .setDbColumnUnderline(true)   // 表名 字段名 是否使用下滑线命名
                //.setTablePrefix("tb_") // 去除表前缀
                .setRestControllerStyle(true)
                .setNaming(NamingStrategy.underline_to_camel)  underline_to_camel数据库表映射到实体的命名策略

                //设置父类路径
                .setSuperMapperClass("com.baomidou.mybatisplus.core.mapper.BaseMapper")
                .setSuperServiceClass("com.baomidou.mybatisplus.extension.service.IService")
                .setSuperServiceImplClass("com.baomidou.mybatisplus.extension.service.impl.ServiceImpl");
                //.setSuperEntityClass("com.baomidou.mybatisplus.extension.activerecord.Model");


        // 全局配置
        config.setActiveRecord(true)   //是否支持AR模式
                .setAuthor("WangShuai")   // 设置作者
                .setOutputDir(dir)   // 设置生成的目标路径(绝对路径)
                .setIdType(IdType.AUTO) //主键策略
                .setBaseColumnList(true)  // 设置sql片段
                .setBaseResultMap(true)  // resultMap
                .setEnableCache(false)   // 不开缓存
                .setMapperName("%sMapper")
                .setXmlName("%sMapper")
                .setOpen(false) //生成之后 默认打开文件夹
                .setFileOverride(false);  // 每一次生成需要覆盖
        if (!serviceNameStartWithI) {
            config.setServiceName("%sService");
        }
        new AutoGenerator().setGlobalConfig(config)

                .setDataSource(dataSourceConfig)
                .setStrategy(strategyConfig)
                .setPackageInfo(
                        new PackageConfig()
                                .setParent(packageName)
                                .setController("controller")
                                .setEntity("pojo")
                ).execute();
    }

    private void generateByTables(String packageName, String dir,String... tableNames) {
        generateByTables(true, packageName, dir, tableNames);
    }
}

需要注意 strategyConfig.setExclude(null)
排除哪些表不生成//null == 默认全部生成
strategyConfig.setInclude(tableNames);
生成哪些表 // 多个传数组

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值