MyBatis-Plus生成代码类——基础配置

1.添加依赖

<dependency>
    <groupId>com.baomidougroupId>
    <artifactId>mybatis-plus-boot-starterartifactId>
    <version>3.3.2version>
dependency>
<dependency>
    <groupId>com.baomidougroupId>
    <artifactId>mybatis-plus-generatorartifactId>
    <version>3.3.2version>
dependency>
<dependency>
    <groupId>org.apache.velocitygroupId>
    <artifactId>velocity-engine-coreartifactId>
    <version>2.2version>
dependency>

2.代码生成

package per.mx.springboot.util;

import com.baomidou.mybatisplus.annotation.DbType;
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.LikeTable;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.BeetlTemplateEngine;

/**
 * Mybatis Plus 代码生成器
 */
public class MPCodeGenerator {

    public static void main(String[] args) {
        AutoGenerator autoGenerator = new AutoGenerator();

        // 数据源配置
        DataSourceConfig dataSourceConfig = new DataSourceConfig()
                .setDbType(DbType.MYSQL)
                .setUrl("jdbc:mysql://localhost:3306/demo?serverTimeZone=UTC+8")
                .setDriverName("com.mysql.cj.jdbc.Driver")
                .setUsername("root")
                .setPassword("123456");
        autoGenerator.setDataSource(dataSourceConfig);

        // 数据库表配置
        StrategyConfig strategyConfig = new StrategyConfig()
                .setSkipView(true) // 跳过视图
                .setNaming(NamingStrategy.underline_to_camel) // 表名转换策略
                .setColumnNaming(NamingStrategy.underline_to_camel) // 字段名转换策略
                .setTablePrefix("t_") // 去掉表前缀
                /*.setInclude("t_user","t_role") // 要生成的表
                .setExclude("seckill") // 不需要生成的表*/
                .setLikeTable(new LikeTable("t\\_")) // 以t_开头的表
                .setEntityColumnConstant(true) // 实体字段常量
                .setChainModel(true) // 链式调用模型
                .setEntityLombokModel(true) // lombok
                .setRestControllerStyle(true) // 生成controller
                .setEntityTableFieldAnnotationEnable(true); // 实体字段注解
        autoGenerator.setStrategy(strategyConfig);

        // 包配置,其他默认包名controller、service、service.impl、mapper、mapper.xml、entity
        PackageConfig packageConfig = new PackageConfig()
                .setParent("per.mx.springboot"); // 设置父包
        autoGenerator.setPackageInfo(packageConfig);

        // 全局配置
        GlobalConfig globalConfig = new GlobalConfig()
                .setAuthor("demo")
                .setOutputDir(System.getProperty("user.dir") + "/src/main/java") // 输出路径
                .setOpen(false) // 生成文件后不打开文件夹
                .setFileOverride(true) // 是否覆盖文件
                .setSwagger2(true); // 生成swagger注解
        autoGenerator.setGlobalConfig(globalConfig);

        // 随便设置一个模板渲染,不然3.3.2版本会报错
        autoGenerator.setTemplateEngine(new BeetlTemplateEngine());

        autoGenerator.execute();
    }

}

注意:生成好后,默认的xml文件在mapper.xml包下,可自行转移。

你可能感兴趣的:(MyBatis)