Mybatis-plus 代码生成器(版本:3.5.1)

Mybatis-plus代码生成器

1. 引入依赖

<!-- mysql连接 -->
<dependency>
    <groupId>com.mysql</groupId>
    <artifactId>mysql-connector-j</artifactId>
    <scope>runtime</scope>
</dependency>
<!-- mybatis-plus依赖 -->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.1</version>
</dependency>
<!-- mybatis-plus代码生成 -->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-generator</artifactId>
    <version>3.5.1</version>
</dependency>
<!-- 以上两个依赖版本号要一致 -->
<!-- MyBatis-Plus模板引擎 -->
<dependency>
    <groupId>org.apache.velocity</groupId>
    <artifactId>velocity</artifactId>
    <version>1.7</version>
</dependency>

2. 修改application.yml配置文件

# 配置数据源
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/db1?useSSL=false&&characterEncoding=utf-8&&serverTimezone=Asia/Shanghai
    hikari:
      username: root
      password: 1234
      
# mybatis-plus的配置     
mybatis-plus:
  mapper-locations: classpath*:mapper/*Mapper.xml
  configuration:
    # 打开mybatis运行sql的日志
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    #      configuration:
    #        关闭打印sql查询数据
    #        log-impl: org.apache.ibatis.logging.nologging.NoLoggingImpl
    #                   开启打印sql查询数据
    #                   org.apache.ibatis.logging.stdout.StdOutImpl

    map-underscore-to-camel-case: true
  type-aliases-package: com.aaa.entity
#  逻辑删除组件
#  global-config:
#    db-config:
#      logic-delete-field: flag # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2)
#      logic-delete-value: 1 # 逻辑已删除值(默认为 1)
#      logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)

3. 编写生成类

package com.aaa;

import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.config.*;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;

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

@SpringBootTest
public class GeneratorServiceEntity {
    // 路径设置
    public String PROJECT_DIR = "E:\\WorkSpace3\\mp-demo\\";    // 项目路径
    public String PACKAGE = "com";      // 设置父包名  全名 com.aaa
    public String START_PACKAGE = "aaa"; // 设置父包模块名(即启动类所在包的包名)
    // 数据库设置
    public String URL = "jdbc:mysql://localhost:3306/db1?serverTimezone=Asia/Shanghai";
    public String USERNAME = "root";
    public String PASSWORD = "1234";
    // 要生产的表
    public List<String> TABLES = Arrays.asList("tbl_book");
    // 相对路径(无需改动)
    public String JAVA_DIR = PROJECT_DIR  + "src\\main\\java\\";
    public String MAPPER_XML_DIR = PROJECT_DIR + "src\\main\\resources\\mapper\\";

    @Test
    public void contextLoads() {
        FastAutoGenerator.create(URL, USERNAME, PASSWORD)
                // 全局配置
                .globalConfig(builder -> {
                    builder.author("shang") // 设置作者
//                            .enableSwagger() // 开启 swagger 模式
                            .fileOverride() // 覆盖已生成文件
//                            .disableOpenDir()   // 不打开目录
                            .outputDir(JAVA_DIR); // 指定输出目录
                })
                // 包配置
                .packageConfig(builder -> {
                    builder.parent(PACKAGE) // 设置父包名
                            .moduleName(START_PACKAGE) // 设置父包模块名
                            .pathInfo(Collections.singletonMap(OutputFile.mapperXml, MAPPER_XML_DIR)); // 设置mapperXml生成路径
                })
                // 策略配置
                .strategyConfig(builder -> {
                    builder.addInclude(TABLES) // 设置需要生成的表名
                            .addTablePrefix("t_", "c_","tbl_") // 设置过滤表前缀
                            // Entity策略配置
                            .entityBuilder()
                            .enableLombok() // 开启 lombok 模型
//                            .logicDeleteColumnName("")    //  逻辑删除字段名(数据库)
//                            .logicDeletePropertyName("")  //  逻辑删除属性名(实体)
//                            .enableTableFieldAnnotation() //  开启生成实体时生成字段注解
                            // Controller策略配置
                            .controllerBuilder()
                            .enableRestStyle() // 开启生成 @RestController 控制器
                            // Service策略配置
                            .serviceBuilder()
                            .formatServiceFileName("%sService")
                            .formatServiceImplFileName("%sServiceImpl")
                            // Mapper策略配置
                            .mapperBuilder()
                            .enableMapperAnnotation()   // 开启 @Mapper 注解
                    ;
                })
//                .templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker引擎模板,默认的是Velocity引擎模板
                .execute();
    }
}

需要修改的地方

在这里插入图片描述

4. 测试:

在controller中编写一个查询所有的接口,其他的都不做改变

在这里插入图片描述

浏览器访问该接口

在这里插入图片描述

成功!