mybatis-plus 代码生成器

生成entity -> mapper-> service ->controller所有的接口,实现,一键完成。

1. 轮子

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>

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

        <!-- code generator! -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.4.1</version>
        </dependency>

        <!-- 默认的模板对象 -->
        <dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity-engine-core</artifactId>
            <version>2.2</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.9.2</version>
        </dependency>


        <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger-ui -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.9.2</version>
        </dependency>

2. 核心代码

开箱即用。配置好数据库地址

package cn.bitqian;


import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.annotation.FieldFill;
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.po.TableFill;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;

import java.util.ArrayList;
import java.util.List;

/**
 * 使用mybatis 生成代码 all
 *
 * <a>
 *     https://baomidou.com/config/generator-config.html
 * </p>
 * @author echo lovely
 * @date 2020/11/17 09:07
 */

public class CodeGenerator {

    public static void main(String[] args) {

        // 代码生成器
        AutoGenerator autoGenerator = new AutoGenerator();

        // 全局配置
        GlobalConfig globalConfig = new GlobalConfig();

        globalConfig.setFileOverride(false);
        globalConfig.setOpen(false);
        // 出掉接口
        globalConfig.setServiceName("%sService");

        // 设置输出目录
        globalConfig.setOutputDir(System.getProperty("user.dir") + "/src/main/java");
        globalConfig.setAuthor("echo lovely");
        globalConfig.setDateType(DateType.ONLY_DATE);

        // 开启swagger
        globalConfig.setSwagger2(true);

        autoGenerator.setGlobalConfig(globalConfig);

        // dataSource 配置
        DataSourceConfig dataSourceConfig = new DataSourceConfig();
        dataSourceConfig.setUrl("jdbc:mysql://localhost:3306/mybatis_study?useUnicode=true&useSSL=false&characterEncoding=utf8&serverTimezone=Asia/Shanghai");
        dataSourceConfig.setDriverName("com.mysql.cj.jdbc.Driver");
        dataSourceConfig.setUsername("root");
        dataSourceConfig.setPassword("123456");

        dataSourceConfig.setDbType(DbType.MYSQL);

        autoGenerator.setDataSource(dataSourceConfig);

        // 包配置
        PackageConfig pkgConfig = new PackageConfig();
        pkgConfig.setParent("cn.bitqian");

        pkgConfig.setMapper("mapper");
        pkgConfig.setEntity("entity");
        pkgConfig.setService("service");
        pkgConfig.setController("controller");

        autoGenerator.setPackageInfo(pkgConfig);

        // 设置模板引擎
        autoGenerator.setTemplateEngine(null);
        autoGenerator.setTemplate(null);

        // 自定义策略
        StrategyConfig strategy = new StrategyConfig();

        // camel命名规则
        strategy.setNaming(NamingStrategy.underline_to_camel);
        strategy.setColumnNaming(NamingStrategy.underline_to_camel);
        strategy.setControllerMappingHyphenStyle(true); // id_1_1
        strategy.setRestControllerStyle(true);
        // 开启lombok注解
        strategy.setEntityLombokModel(true);

        // 设置要生成的表 ... 这里有三个表
        strategy.setInclude("account", "user", "role");

        // 逻辑删除 的字段
        // strategy.setLogicDeleteFieldName("deleted");
        // 自动填充配置

		// 自动填充的字段
        List<TableFill> tableFillList = new ArrayList<>();
        TableFill fill1 = new TableFill("date", FieldFill.INSERT);
        tableFillList.add(fill1);

        // 设置填充的字段
        strategy.setTableFillList(tableFillList);

        // 乐观锁 字段
        strategy.setVersionFieldName("version");

        autoGenerator.setStrategy(strategy);

        // 开启代码生成...
        autoGenerator.execute();
    }


}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值