mybatis-plus代码生成器使用(generator)

2023-05-06 21:37:24 浏览数 (2)

mybatis-plus generator 本文主要记录在 springboot项目中使用最新版 mybatis plus generator代码生成。

1、引入依赖

首先在springboot项目中引入mybatis plus、mybatis plus generator的依赖,如下所示:

代码语言:javascript复制
<!--   mybatis plus     -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.5.3.1</version>
        </dependency>
        <!--   mybatis plus  generator   -->
        <!-- https://mvnrepository.com/artifact/com.baomidou/mybatis-plus-generator -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.5.3.1</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.velocity/velocity-engine-core -->
        <dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity-engine-core</artifactId>
            <version>2.3</version>
        </dependency>

2、编写代码生成器配置类

对于新版的mybatis plus generator,官方提供了两种代码生成方式,一种是交互式生成,另一种是快速生成,我这里使用的是快速生成,具体代码如下所示:

代码语言:javascript复制
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.fill.Column;

import java.util.Arrays;
import java.util.Collections;
import java.util.List;


public class MybatisPlusGenerator  {
    public static void main(String[] args) {
    FastAutoGenerator.create("jdbc:mysql://127.0.0.1:3306/fruit_mall_db?characterEncoding=UTF-8&useUnicode=true&useSSL=false&serverTimezone=Asia/Shanghai","root","123456!")
            // 全局配置
            .globalConfig((scanner, builder) -> builder.author(scanner.apply("请输入作者名称?")).fileOverride())
            // 包配置
            .packageConfig((scanner, builder) -> builder.parent(scanner.apply("请输入包名?")))
            // 策略配置
            .strategyConfig((scanner, builder) -> builder.addInclude(getTables(scanner.apply("请输入表名,多个英文逗号分隔?所有输入 all")))
                    .controllerBuilder().enableRestStyle().enableHyphenStyle()
                    .entityBuilder().enableLombok().addTableFills(
                            new Column("create_time", FieldFill.INSERT)
                    ).build())
            /*
                模板引擎配置,默认 Velocity 可选模板引擎 Beetl 或 Freemarker
               .templateEngine(new BeetlTemplateEngine())
               .templateEngine(new FreemarkerTemplateEngine())
             */
            .execute();

    }
    // 处理 all 情况
    protected static List<String> getTables(String tables) {
        return "all".equals(tables) ? Collections.emptyList() : Arrays.asList(tables.split(","));
    }


}

运行后需要在控制台输入作者名、包名、以及数据库表名,生成代码后会打开生成代码所在文件夹。上面只是一个简单的使用方式。对于配置类具体的配置则可以查看官方的代码生成器配置文档,点击跳转

3、可能遇到的问题

如果遇到Caused by: java.sql.SQLNonTransientConnectionException: Public Key Retrieval is not allowed错误,则可点击跳转,参考下面的文章: 该错误解决方法文章

0 人点赞