【保姆级喂饭教程】Mybatis Plus Generator 3.5.12最新版代码生成器配置教程

前言

Mybatis Plus的代码生成器十分好用,也不断的再更新,找了一圈目前没有最新的3.5.12版本的配置教程,官网的示例也不够好,所以自己总结一篇。

一、Mybatis Plus 代码生成器官网

https://baomidou.com/guides/new-code-generator/
上面这个是新版代码生成器的指南页面,主要是一个简介和使用示例,mybatis-plus-generator 3.5.1之前使用的是逐项配置的方式,而从3.5.1开始,引入了更加灵活和高效的 builder 模式,使用是注意自己项目的版本,如果是新项目就用最新版本好了。
https://baomidou.com/reference/new-code-generator-configuration/
上面这个是代码生成器的具体配置页面,详细介绍了每个模块的参数以及简单示例,但是缺乏一个粘贴即用的示例,这也是本教程的目的。


二、全部配置清单版

1. pom.xml

代码生成器最少只需要mybatis-plus-boot-startermybatis-plus-generatorfreemarker这三个依赖,如果没有添加模板引擎依赖会报错
【沉浸式解决问题】Caused by: java.lang.ClassNotFoundException: freemarker.template.Configuration

	<dependencies>
		<!-- 提供注解-->
		<dependency>
			<groupId>com.baomidou</groupId>
			<artifactId>mybatis-plus-boot-starter</artifactId>
			<version>3.5.12</version>
		</dependency>
		<!-- 代码生成器-->
		<dependency>
			<groupId>com.baomidou</groupId>
			<artifactId>mybatis-plus-generator</artifactId>
			<version>3.5.12</version>
		</dependency>
		<!-- 模板引擎-->
		<dependency>
			<groupId>org.freemarker</groupId>
			<artifactId>freemarker</artifactId>
			<scope>compile</scope>
		</dependency>
	</dependencies>

2. MybatisPlusGenerator.java

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.IGenerateMapperMethodHandler;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
import com.baomidou.mybatisplus.generator.config.INameConvert;
import com.baomidou.mybatisplus.generator.config.po.LikeTable;
import com.baomidou.mybatisplus.generator.config.po.TableField;
import com.baomidou.mybatisplus.generator.config.po.TableInfo;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.config.rules.DbColumnType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
import com.baomidou.mybatisplus.generator.keywords.MySqlKeyWordsHandler;
import com.baomidou.mybatisplus.generator.model.ClassAnnotationAttributes;
import com.baomidou.mybatisplus.generator.model.MapperMethod;
import com.gwyy.ybws.common.core.base.BaseEntity;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.cache.impl.PerpetualCache;
import org.apache.ibatis.type.JdbcType;

import java.io.File;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Set;


public class MybatisPlusGenerator {

    /**
     * 全部配置清单版
     */
    public static void generator1() {
        /*
        * FastAutoGenerator
        * 0、create  创建构造器,配置数据源
        * 1、DataSourceConfig.Builder  数据库配置
        * 2、GlobalConfig.Builder  全局配置
        * 3、PackageConfig.Builder  包配置
        * 4、StrategyConfig.Builder  策略配置
        *   4.1、全局策略配置
        *   4.2、Entity策略配置
        *   4.3、Controller策略配置
        *   4.4、Service策略配置
        *   4.5、Mapper策略配置
        * 5、InjectionConfig.Builder  注入配置
        * 6、templateEngine  选择模板引擎
        * 7、执行
        * */
        // 0、使用FastAutoGenerator构造器,同时进行数据源配置
        FastAutoGenerator.create(new DataSourceConfig.Builder("url","user","root"))
                // 1、数据库配置,一般没特殊需求不用配置
                .dataSourceConfig(builder -> {
                    builder.schema("mybatis-plus") // 设置数据库schema(默认值)
                            .keyWordsHandler(new MySqlKeyWordsHandler()) // 设置数据库关键字处理器(默认值)
                            // 当 MySQL 下 tinyint 字段长度大于 1 时,默认转换成 Byte,如果想继续转换成 Integer,可使用如下代码
                            .typeConvertHandler((globalConfig, typeRegistry, metaInfo) -> {
                                // 兼容旧版本转换成Integer
                                if (JdbcType.TINYINT == metaInfo.getJdbcType()) {
                                    return DbColumnType.INTEGER;
                                }
                                return typeRegistry.getColumnType(metaInfo);
                            });
                })
                // 2、全局配置
                .globalConfig(builder -> {
                    builder.outputDir(System.getProperty("os.name").toLowerCase().contains("windows") ? "D://" : "/tmp") // 设置文件的输出目录【 windows:D://  linux or mac:/tmp 】
                            .disableOpenDir() // 禁止打开输出目录(默认 true)
                            .author("baomidou") // 设置作者(默认值)
                            .enableKotlin() // 开启 kotlin 模式(默认 false)
                            .enableSwagger() // 开启 swagger 模式(默认 false),与 springdoc 不可同时使用
                            .enableSpringdoc() // 开启 springdoc 模式(默认 false),与 swagger 不可同时使用
                            .disableServiceInterface() // 禁止生成service 接口(默认 true);增加此开关的原因:在某些项目实践中,只需要生成service实现类,不需要抽象sevice接口;针对某些项目,生成service接口,开发时反而麻烦,这种情况,可以将该属性设置为false
                            .dateType(DateType.TIME_PACK) // 设置时间类型对应策略(默认值),数据库时间类型 到 实体类时间类型 对应策略
                            .commentDate(() -> new SimpleDateFormat("yyyy-MM-dd").format(new Date())) // 设置注释日期(默认值),example: () -> LocalDateTime.now().format(DateTimeFormatter.ISO_DATE)
                            .commentDate("yyyy-MM-dd"); // 设置注释日期,直接使用格式也可以
                })
                // 3、包配置
                .packageConfig(builder -> {
                    builder.parent("com.baomidou") // 设置父包名(默认值)
                            .moduleName("") // 设置模块名(默认值),就是父包名的子模块名称,适用于单体多模块项目
                            .entity("entity") // 设置 Entity 包名(默认值)
                            .service("service") // 设置 Service 包名(默认值)
                            .serviceImpl("service.impl") // 置 Service Impl 包名(默认值)设
                            .mapper("mapper") // 设置 Mapper 包名(默认值)
                            .xml("mapper.xml") // 设置 Mapper XML 包名(默认值)
                            .controller("controller") // 设置 Controller 包名(默认值)
                            .pathInfo(new HashMap<>()) // 用一个map直接设置各个包的路径,主要用来修改mapper.xml路径,否则默认在java/mapper的目录下,例:Collections.singletonMap(OutputFile.mapperXml, "/path/to/xml")
                            .joinPackage(""); // 连接父子包名,整体目录结构为 outputDir.parent.moduleName.subPackage,适用于微服务项目
                })
                // 4、策略配置
                .strategyConfig(builder -> {
                    builder
                            // 4.1、全局策略配置
                            .enableCapitalMode() // 开启大写命名(默认 false)
                            .enableSkipView() // 开启跳过视图(默认 false)
                            .disableSqlFilter() // 禁用sql过滤(默认 false),语法不能支持使用sql过滤表的话,可以考虑关闭此开关.
                            .enableSchema() // 启用 schema(默认 false),多 schema 场景时启用
                            .addTablePrefix() // 增加过滤表前缀,支持可变参数和List列表
                            .addTableSuffix() // 增加过滤表后缀,支持可变参数和List列表
                            .addFieldPrefix() // 增加过滤字段前缀,支持可变参数和List列表
                            .addFieldSuffix() // 增加过滤字段后缀,支持可变参数和List列表
                            .addInclude() // 增加表匹配(内存过滤),支持可变参数和List列表,与 addExclude 互斥,只能配置一项,支持正则匹配,如 ^t_.* 匹配所有以 t_ 开头的表名
                            .addExclude() // 增加表排除匹配(内存过滤),支持可变参数和List列表,与 addInclude 互斥,只能配置一项,支持正则匹配,如 .*st$ 匹配所有以 st 结尾的表名
                            .likeTable(new LikeTable("")) // 模糊表匹配(SQL 过滤),与 notLikeTable 互斥,只能配置一项
                            .notLikeTable(new LikeTable("")) // 模糊表排除(SQL 过滤),与 likeTable 互斥,只能配置一项
                            .outputFile((path, ot) -> new File(path)) // 自定义模板输出文件处理,暂时不清楚是干啥的

                            // 4.2、Entity策略配置
                            .entityBuilder()
                            .nameConvert(new INameConvert() {
                                @Override public String entityNameConvert(TableInfo tableInfo) { return tableInfo.getName(); }
                                @Override public String propertyNameConvert(TableField field) { return field.getName(); }}) // 自定义名称转换实现
                            .superClass(BaseEntity.class) // 设置父类,使用公共字段时使用
                            .superClass("com.baomidou.global.BaseEntity") // 设置父类,也可以用 类全称带包名
                            .disableSerialVersionUID() // 禁用生成 serialVersionUID(默认 true)
                            .enableSerialAnnotation() // 启用生成 @Serial 注解(默认 false),需JAVA 14
                            .enableColumnConstant() // 开启生成字段常量(默认 false),public static final String ID = "test_id";
                            .enableChainModel() // 开启链式模型(默认 false)
                            .enableLombok() // 开启lombok模型(默认 false),默认添加Getter、Setter、ToString
                            .enableLombok(new ClassAnnotationAttributes("@Data","lombok.Data")) // 开启lombok模型(默认 false),会把注解属性都加入进去,无论是否启用GlobalConfig的isKotlin(),同时get,set,toString都将不会生成,需自行控制添加
                            .enableRemoveIsPrefix() // 开启Boolean类型字段移除is前缀(默认 false)
                            .enableTableFieldAnnotation() // 开启生成实体时生成字段注解(默认 false)
                            .enableActiveRecord() // 开启 ActiveRecord 模式(默认 false)
                            .versionColumnName("version") // 设置乐观锁字段名(数据库字段),versionColumnName 与 versionPropertyName 二选一即可
                            .versionPropertyName("version") // 设置乐观锁属性名(实体),versionColumnName 与 versionPropertyName 二选一即可
                            .logicDeleteColumnName("deleted") // 设置逻辑删除字段名(数据库字段),logicDeleteColumnName 与 logicDeletePropertyName 二选一即可
                            .logicDeletePropertyName("deleteFlag") // 设置逻辑删除属性名(实体),logicDeleteColumnName 与 logicDeletePropertyName 二选一即可
                            .naming(NamingStrategy.underline_to_camel) // 设置数据库表映射到实体的命名策略(默认值 下划线转驼峰命名)
                            .columnNaming(NamingStrategy.underline_to_camel) // 设置数据库表字段映射到实体的命名策略(默认值:null,未指定按照 naming 执行)
                            .addSuperEntityColumns() // 添加父类公共字段,支持可变参数和List列表
                            .addIgnoreColumns() // 添加忽略字段,支持可变参数和List列表
                            .addTableFills() // 添加表字段填充,支持可变参数和List列表
                            .idType(IdType.AUTO) // 设置全局主键类型(默认值 自增)
                            .convertFileName(entityName -> entityName) // 自定义转换输出文件名称
                            .formatFileName("format") // 设置格式化文件名称
                            .enableFileOverride() // 开启覆盖已有文件(默认 false),针对 Entity
                            .javaTemplate("path") // 指定模板路径
                            .kotlinTemplatePath("path") // 设置自定义模板路径
                            .disable() // 禁用 Entity 生成(默认 true)
                            .addClassAnnotation(new ClassAnnotationAttributes("@Data","lombok.Data")) // 添加类注解,这里主要用于添加其他注解
                            .tableFieldAnnotationHandler((tableInfo, tableField) -> null) // 自定义字段注解处理器
                            .tableAnnotationHandler((tableInfo, entity) -> null) // 自定义表注解处理器
                            .toString(true) // 设置是否生成ToString方法(默认 true)
                            .fieldUseJavaDoc(true) // 设置字段是否生成文档注释(默认 true),当注释字段注释不为空才生效
                            .importPackageFunction(strings -> null) // 自定义导包处理方法
                            .annotationAttributesFunction(annotationAttributes -> null) // 自定义注解处理方法 (含类与字段)

                            // 4.3、Controller策略配置
                            .controllerBuilder()
                            .superClass("") // 设置父类,可以用 类全称带包名 或 父类.class
                            .enableHyphenStyle() // 开启驼峰转连字符(默认 false)
                            .enableRestStyle() // 开启生成 @RestController 控制器(默认 false),采用 restful 风格的api
                            .convertFileName(entityName -> null) // 自定义转换输出文件名称
                            .formatFileName("format") // 格式化文件名称
                            .enableFileOverride() // 开启覆盖已有文件(默认 false),针对 Controller
                            .disable() // 禁用 Controller 生成(默认 true)
                            .template("path") // 设置自定义模板路径

                            // 4.4、Service策略配置
                            .serviceBuilder()
                            .superServiceClass("") // 设置接口父类,可以用 类全称带包名 或 父类.class
                            .superServiceImplClass("") // 设置实现类父类,可以用 类全称带包名 或 父类.class
                            .convertServiceFileName(entityName -> null) // 自定义转换输出service接口文件名称
                            .convertServiceImplFileName(entityName -> null) // 自定义转换输出service实现类文件名称
                            .formatServiceFileName("format") // 自定义格式化service接口文件名称
                            .formatServiceImplFileName("format") // 自定义格式化service实现类文件名称
                            .enableFileOverride() // 开启覆盖已有文件(默认 false),针对 Service
                            .disable() // 禁用 Service 接口和实现类生成(默认 true)
                            .disableService() // 禁用 Service 接口生成(默认 true)
                            .disableServiceImpl() // 禁用 Service 实现类生成(默认 true)
                            .serviceTemplate("path") // 设置自定义service接口模板路径
                            .serviceImplTemplate("path") // 设置自定义service实现类模板路径

                            // 4.5、Mapper策略配置
                            .mapperBuilder()
                            .superClass("") // 设置父类,可以用 类全称带包名 或 父类.class
                            .mapperAnnotation(Mapper.class) // 自定义添加注解,例:@Mapper注解 Mapper.class
                            .enableBaseResultMap() // 开启 BaseResultMap(默认 false),如果配置了resultMap,mybatis会根据查询到的条目数量自动进行判断,如果是一条就返回对象,如果是多条就返回List对象列表
                            .enableBaseColumnList() // 开启 BaseColumnList
                            .cache(PerpetualCache.class) // 自定义缓存实现类,需实现Cache接口
                            .convertMapperFileName(entityName -> null) // 自定义输出Mapper文件名称转换
                            .convertXmlFileName(entityName -> null) // 自定义转换Xml文件名称处理
                            .formatMapperFileName("format") // 自定义格式化Mapper文件名称
                            .formatXmlFileName("format") // 格式化Xml文件名称
                            .enableFileOverride() // 开启覆盖已有文件(默认 false),针对 Mapper
                            .mapperTemplate("path") // 设置自定义Mapper文件模板路径
                            .mapperXmlTemplate("path") // 设置自定义Xml文件模板路径
                            .disable() // 禁用Mapper接口和Xml文件生成(默认 true)
                            .disableMapper() // 禁用Mapper接口生成(默认 true)
                            .disableMapperXml() // 禁用MapperXml生成(默认 true)
                            .generateMapperMethodHandler(new IGenerateMapperMethodHandler() {
                                @Override public List<MapperMethod> getMethodList(TableInfo tableInfo) { return null; }
                                @Override public Set<String> getImportPackages(TableInfo tableInfo) { return null; }}) // 自定义Mapper层方法生成处理器
                            .importPackageFunction(strings -> null); // 自定义导包处理方法
                })
                // 5、注入配置
                .injectionConfig(builder -> {
                    builder.beforeOutputFile((tableInfo, stringObjectMap) -> {}) // 输出文件之前执行的逻辑,在生成文件之前执行自定义逻辑,如打印表信息或修改配置数据
                            .customMap(new HashMap<>()) // 自定义配置 Map 对象,用于在模板中访问自定义的配置信息,如项目名称、作者等
                            .customFile(new HashMap<>()); // 自定义配置模板文件,用于指定自定义的模板文件路径,可以格式化文件名
                })
                // 6、选择模板引擎
                .templateEngine(new FreemarkerTemplateEngine()) // 设置使用Freemarker引擎模板,默认的是Velocity引擎模板
                // 7、执行
                .execute();

    }
    
}

三、常用配置清单版

public class MybatisPlusGenerator {

    /**
     * 常用配置清单版
     */
    public static void generator2() {
        // 0、使用FastAutoGenerator构造器,同时进行数据源配置
        FastAutoGenerator.create(new DataSourceConfig.Builder("url","user","root"))
                // 2、全局配置
                .globalConfig(builder -> {
                    builder.outputDir((System.getProperty("user.dir")+"/src/main/java")) // 设置文件的输出目录 根目录/src/main/java
                            .disableOpenDir() // 禁止打开输出目录(默认 true)
                            .author("baomidou") // 设置作者(默认值)
                            .enableSwagger() // 开启 swagger 模式(默认 false),与 springdoc 不可同时使用
                            .commentDate("yyyy-MM-dd"); // 设置注释日期,直接使用格式也可以
                })
                // 3、包配置
                .packageConfig(builder -> {
                    builder.parent("com.baomidou") // 设置父包名(默认值)
                            .moduleName("") // 设置模块名(默认值),就是父包名的子模块名称,适用于单体多模块项目
                            .pathInfo(Collections.singletonMap(OutputFile.xml, System.getProperty("user.dir")+"/src/main/resources/mapper")) // 用一个map直接设置各个包的路径,主要用来修改mapper.xml路径,否则默认在java/mapper的目录下,例:Collections.singletonMap(OutputFile.mapperXml, "/path/to/xml")
                            .joinPackage(""); // 连接父子包名,整体目录结构为 outputDir.parent.moduleName.subPackage,适用于微服务项目
                })
                // 4、策略配置
                .strategyConfig(builder -> {
                    builder
                            // 4.1、全局策略配置
                            .enableSkipView() // 开启跳过视图(默认 false)
                            .addInclude() // 增加表匹配(内存过滤),支持可变参数和List列表,与 addExclude 互斥,只能配置一项,支持正则匹配,如 ^t_.* 匹配所有以 t_ 开头的表名

                            // 4.2、Entity策略配置
                            .entityBuilder()
                            .superClass(BaseEntity.class) // 设置父类,使用公共字段时使用
                            .disableSerialVersionUID() // 禁用生成 serialVersionUID(默认 true)
                            .enableChainModel() // 开启链式模型(默认 false)
                            .enableLombok(new ClassAnnotationAttributes("@Data","lombok.Data")) // 开启lombok模型(默认 false),会把注解属性都加入进去,无论是否启用GlobalConfig的isKotlin(),同时get,set,toString都将不会生成,需自行控制添加
                            .enableTableFieldAnnotation() // 开启生成实体时生成字段注解(默认 false)
                            .enableActiveRecord() // 开启 ActiveRecord 模式(默认 false)
                            .versionColumnName("version") // 设置乐观锁字段名(数据库字段),versionColumnName 与 versionPropertyName 二选一即可
                            .logicDeleteColumnName("deleted") // 设置逻辑删除字段名(数据库字段),logicDeleteColumnName 与 logicDeletePropertyName 二选一即可
                            .addSuperEntityColumns() // 添加父类公共字段,支持可变参数和List列表
                            .enableFileOverride() // 开启覆盖已有文件(默认 false),针对 Entity
                            .disable() // 禁用 Entity 生成(默认 true)

                            // 4.3、Controller策略配置
                            .controllerBuilder()
                            .superClass("") // 设置父类,可以用 类全称带包名 或 父类.class
                            .enableRestStyle() // 开启生成 @RestController 控制器(默认 false),采用 restful 风格的api
                            .enableFileOverride() // 开启覆盖已有文件(默认 false),针对 Controller
                            .disable() // 禁用 Controller 生成(默认 true)

                            // 4.4、Service策略配置
                            .serviceBuilder()
                            .superServiceClass("") // 设置接口父类,可以用 类全称带包名 或 父类.class
                            .superServiceImplClass("") // 设置实现类父类,可以用 类全称带包名 或 父类.class
                            .enableFileOverride() // 开启覆盖已有文件(默认 false),针对 Service
                            .disable() // 禁用 Service 接口和实现类生成(默认 true)

                            // 4.5、Mapper策略配置
                            .mapperBuilder()
                            .superClass("") // 设置父类,可以用 类全称带包名 或 父类.class
                            .mapperAnnotation(Mapper.class) // 自定义添加注解,例:@Mapper注解 Mapper.class
                            .enableFileOverride() // 开启覆盖已有文件(默认 false),针对 Mapper
                            .disable(); // 禁用Mapper接口和Xml文件生成(默认 true)
                })
                // 6、选择模板引擎
                .templateEngine(new FreemarkerTemplateEngine()) // 设置使用Freemarker引擎模板,默认的是Velocity引擎模板
                // 7、执行
                .execute();

    }
    
}

四、实际使用版

public class MybatisPlusGenerator {

    /**
     * 实际使用版
     * Spring Boot项目生成全部表示例,有调整可以自己修改
     */
    public static void generator3() {
        FastAutoGenerator.create("jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&useSSL=false&characterEncoding=utf8","root","root")
                .globalConfig(builder -> {
                    builder.outputDir((System.getProperty("user.dir")+"/src/main/java"))
                            .disableOpenDir()
                            .author("baomidou")
                            .enableSwagger();
                })
                .packageConfig(builder -> {
                    builder.parent("com.baomidou")
                            .pathInfo(Collections.singletonMap(OutputFile.xml, System.getProperty("user.dir")+"/src/main/resources/mapper"));
                })
                .strategyConfig(builder -> {
                    builder.enableSkipView()
                            .entityBuilder().enableLombok(new ClassAnnotationAttributes("@Data","lombok.Data"))
                            .mapperBuilder().mapperAnnotation(Mapper.class);
                })
                .templateEngine(new FreemarkerTemplateEngine())
                .execute();

    }
    
    public static void main(String[] args) {
        // generator1(); // 全部配置清单版
        // generator2(); // 常用配置清单版
         generator3(); // 实际使用版
    }
}

五、测试

点击小三角运行
在这里插入图片描述
控制台日志如下:
在这里插入图片描述
结果目录如下:
在这里插入图片描述
目前未开启覆盖设置,再运行一次不会重新生成:
在这里插入图片描述

1. 补充依赖

由于配置了web,swagger,Lombok注解,需要补充对应依赖

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
			<version>2.7.18</version>
			<scope>compile</scope>
		</dependency>
		<dependency>
			<groupId>org.projectlombok</groupId>
			<artifactId>lombok</artifactId>
			<version>1.18.36</version>
			<scope>compile</scope>
		</dependency>
		<dependency>
			<groupId>io.springfox</groupId>
			<artifactId>springfox-swagger2</artifactId>
			<version>3.0.0</version>
		</dependency>

2. 生成结果

  • Test.java
package com.baomidou.entity;

import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;

import java.io.Serializable;

/**
 * <p>
 * 连接测试表
 * </p>
 *
 * @author baomidou
 * @since 2025-05-21
 */
@Data
@ApiModel(value = "Test对象", description = "连接测试表")
public class Test implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * ID
     */
    @ApiModelProperty("ID")
    private Integer id;

    /**
     * 名称
     */
    @ApiModelProperty("名称")
    private String name;
}

  • TestMapper.java
package com.baomidou.mapper;

import com.baomidou.entity.Test;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;

/**
 * <p>
 * 连接测试表 Mapper 接口
 * </p>
 *
 * @author baomidou
 * @since 2025-05-22
 */
@Mapper
public interface TestMapper extends BaseMapper<Test> {

}

  • TestMapper.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.baomidou.mapper.TestMapper">

</mapper>

  • ITestService.java
package com.baomidou.service;

import com.baomidou.entity.Test;
import com.baomidou.mybatisplus.extension.service.IService;

/**
 * <p>
 * 连接测试表 服务类
 * </p>
 *
 * @author baomidou
 * @since 2025-05-21
 */
public interface ITestService extends IService<Test> {

}

  • TestServiceImpl.java
package com.baomidou.service.impl;

import com.baomidou.entity.Test;
import com.baomidou.mapper.TestMapper;
import com.baomidou.service.ITestService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.stereotype.Service;

/**
 * <p>
 * 连接测试表 服务实现类
 * </p>
 *
 * @author baomidou
 * @since 2025-05-21
 */
@Service
public class TestServiceImpl extends ServiceImpl<TestMapper, Test> implements ITestService {

}

  • TestController.java
package com.baomidou.controller;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.stereotype.Controller;

/**
 * <p>
 * 连接测试表 前端控制器
 * </p>
 *
 * @author baomidou
 * @since 2025-05-21
 */
@Controller
@RequestMapping("/test")
public class TestController {

}


后记

此处示例主要用于Spring Boot单体项目,后续准备开一个Spring Cloud开源框架专题,代码生成器的部分配置就需要调整了,主要是包模块、路径、父类这些,还会进行二次封装,提供一些工具方法,例如快速的补充或更新表对应实体类,以及多人员多环境自动读取配置信息等功能。

喜欢的点个关注吧><!祝你永无bug!

/*
                   _ooOoo_
                  o8888888o
                  88" . "88
                  (| -_- |)
                  O\  =  /O
               ____/`---'\____
             .'  \\|     |//  `.
            /  \\|||  :  |||//  \
           /  _||||| -:- |||||-  \
           |   | \\\  -  /// |   |
           | \_|  ''\---/''  |   |
           \  .-\__  `-`  ___/-. /
         ___`. .'  /--.--\  `. . __
      ."" '<  `.___\_<|>_/___.'  >'"".
     | | :  `- \`.;`\ _ /`;.`/ - ` : | |
     \  \ `-.   \_ __\ /__ _/   .-` /  /
======`-.____`-.___\_____/___.-`____.-'======
                   `=---='
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
            佛祖保佑       永无BUG
*/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值