本篇文章为大家展示了用mybatis-plus-generator实现代码自动生成的方法,代码简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

为了解放程序员的双手,减少重复性代码的编写,推荐使用插件:mybatis-plus-generator 进行代码自动生成。下面我将详细介绍通过mybatis-plus-generator 插件自动生成 controller、service、mapper、serviceImpl相关代码。

项目工程目录总览如下:

1. 使用 idea 创建 maven 项目,引入相关依赖,项目pom文件如下所示:

<&#63;xml version="1.0" encoding="UTF-8"&#63;><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.miaoying.generator</groupId> <artifactId>generator-demo</artifactId> <version>1.0-SNAPSHOT</version> <properties> <mybatis-plus.version>3.0.1</mybatis-plus.version> <mysql.connector.java.version>8.0.19</mysql.connector.java.version> <springfox-swagger.version>2.9.2</springfox-swagger.version> </properties> <dependencies> <!-- mybatisPlus 核心库 --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>${mybatis-plus.version}</version> </dependency> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-generator</artifactId> <version>${mybatis-plus.version}</version> </dependency> <!-- 提供mysql驱动 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>${mysql.connector.java.version}</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>RELEASE</version> <scope>compile</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>RELEASE</version> <scope>compile</scope> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>${springfox-swagger.version}</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>${springfox-swagger.version}</version> </dependency> </dependencies></project>

2. 在资源文件夹里新增6个文件:

2.1. controller.java.vm

package ${package.Controller};import org.springframework.web.bind.annotation.RequestMapping;#if(${restControllerStyle})import org.springframework.web.bind.annotation.RestController;#elseimport org.springframework.stereotype.Controller;#end#if(${superControllerClassPackage})import ${superControllerClassPackage};#end/** * @auther ${author} * @create ${cfg.dateTime} * @describe $!{table.comment}前端控制器 */#if(${restControllerStyle})@RestController#else@Controller#end@RequestMapping("#if(${package.ModuleName})/${package.ModuleName}#end/#if(${controllerMappingHyphenStyle})${controllerMappingHyphen}#else${table.entityPath}#end")#if(${kotlin})class ${table.controllerName}#if(${superControllerClass}) : ${superControllerClass}()#end#else#if(${superControllerClass})public class ${table.controllerName} extends ${superControllerClass} {#elsepublic class ${table.controllerName} {#end}#end

2.2. entity.java.vm

package ${package.Entity};#foreach($pkg in ${table.importPackages})import ${pkg};#endimport com.baomidou.mybatisplus.annotation.*;#if(${swagger2})import io.swagger.annotations.ApiModel;import io.swagger.annotations.ApiModelProperty;import com.fasterxml.jackson.annotation.JsonInclude;#end#if(${entityLombokModel})import lombok.Data;#end/** * @auther ${author} * @create ${cfg.dateTime} * @describe $!{table.comment}实体类 */#if(${entityLombokModel})@Data#end@TableName("${table.name}")#if(${swagger2})@JsonInclude(JsonInclude.Include.NON_NULL)@ApiModel(value="${entity}对象", description="$!{table.comment}")#end#if(${superEntityClass})public class ${entity} extends ${superEntityClass}#if(${activeRecord})<${entity}>#end {#elseif(${activeRecord})public class ${entity} extends Model<${entity}> {#elsepublic class ${entity} implements Serializable {#end private static final long serialVersionUID = 1L;## ---------- BEGIN 字段循环遍历 ----------#foreach($field in ${table.fields})#if(${field.keyFlag})#set($keyPropertyName=${field.propertyName})#end#if("$!field.comment" != "") #if(${swagger2}) @ApiModelProperty(value = "${field.comment}") #else /** * ${field.comment} */ #end#end#if(${field.keyFlag})## 主键#if(${field.keyIdentityFlag}) @TableId(value = "${field.name}", type = IdType.AUTO)#elseif(!$null.isNull(${idType}) && "$!idType" != "") @TableId(value = "${field.name}", type = IdType.${idType})#elseif(${field.convert}) @TableId("${field.name}")#end## 普通字段#elseif(${field.fill})## ----- 存在字段填充设置 -----#if(${field.convert}) @TableField(value = "${field.name}", fill = FieldFill.${field.fill})#else @TableField(fill = FieldFill.${field.fill})#end#else @TableField("${field.name}")#end## 乐观锁注解#if(${versionFieldName}==${field.name}) @Version#end## 逻辑删除注解#if(${logicDeleteFieldName}==${field.name}) @TableLogic#end private ${field.propertyType} ${field.propertyName};#end## ---------- END 字段循环遍历 ----------#if(!${entityLombokModel})#foreach($field in ${table.fields})#if(${field.propertyType.equals("boolean")})#set($getprefix="is")#else#set($getprefix="get")#end public ${field.propertyType} ${getprefix}${field.capitalName}() { return ${field.propertyName}; }#if(${entityBuilderModel}) public ${entity} set${field.capitalName}(${field.propertyType} ${field.propertyName}) {#else public void set${field.capitalName}(${field.propertyType} ${field.propertyName}) {#end this.${field.propertyName} = ${field.propertyName};#if(${entityBuilderModel}) return this;#end }#end#end#if(${entityColumnConstant})#foreach($field in ${table.fields}) public static final String ${field.name.toUpperCase()} = "${field.name}";#end#end#if(${activeRecord}) @Override protected Serializable pkVal() {#if(${keyPropertyName}) return this.${keyPropertyName};#else return null;#end }#end#if(!${entityLombokModel}) @Override public String toString() { return "${entity}{" +#foreach($field in ${table.fields})#if($!{foreach.index}==0) "${field.propertyName}=" + ${field.propertyName} +#else ", ${field.propertyName}=" + ${field.propertyName} +#end#end "}"; }#end}

2.3. mapper.java.vm

package ${package.Mapper};import ${package.Entity}.${entity};import ${superMapperClassPackage};/** * @auther ${author} * @create ${cfg.dateTime} * @describe $!{table.comment}mapper类 */#if(${kotlin})interface ${table.mapperName} : ${superMapperClass}<${entity}>#elsepublic interface ${table.mapperName} extends ${superMapperClass}<${entity}> {}#end

2.4. mapper.xml.vm

<&#63;xml version="1.0" encoding="UTF-8"&#63;><!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="${package.Mapper}.${table.mapperName}">#if(${enableCache}) <!-- 开启二级缓存 --> <cache type="org.mybatis.caches.ehcache.LoggingEhcache"/>#end#if(${baseResultMap}) <!-- 通用查询映射结果 --> <resultMap id="BaseResultMap" type="${package.Entity}.${entity}">#foreach($field in ${table.fields})#if(${field.keyFlag})##生成主键排在第一位 <id column="${field.name}" property="${field.propertyName}" />#end#end#foreach($field in ${table.commonFields})##生成公共字段 <result column="${field.name}" property="${field.propertyName}" />#end#foreach($field in ${table.fields})#if(!${field.keyFlag})##生成普通字段 <result column="${field.name}" property="${field.propertyName}" />#end#end </resultMap>#end#if(${baseColumnList}) <!-- 通用查询结果列 --> <sql id="Base_Column_List">#foreach($field in ${table.commonFields}) ${field.name},#end ${table.fieldNames} </sql>#end</mapper>

2.5. service.java.vm

package ${package.Service};import ${package.Entity}.${entity};import ${superServiceClassPackage};/** * @auther ${author} * @create ${cfg.dateTime} * @describe $!{table.comment}服务类 */#if(${kotlin})interface ${table.serviceName} : ${superServiceClass}<${entity}>#elsepublic interface ${table.serviceName} extends ${superServiceClass}<${entity}> {}#end

2.6. serviceImpl.java.vm

package ${package.ServiceImpl};import ${package.Entity}.${entity};import ${package.Mapper}.${table.mapperName};import ${package.Service}.${table.serviceName};import ${superServiceImplClassPackage};import org.springframework.stereotype.Service;/** * @auther ${author} * @create ${cfg.dateTime} * @describe $!{table.comment}服务实现类 */@Service#if(${kotlin})open class ${table.serviceImplName} : ${superServiceImplClass}<${table.mapperName}, ${entity}>(), ${table.serviceName} {}#elsepublic class ${table.serviceImplName} extends ${superServiceImplClass}<${table.mapperName}, ${entity}> implements ${table.serviceName} {}#end

3. 核心类 CodeGenerator.java 内容如下:

package com.miaoying.generator.start;import com.baomidou.mybatisplus.annotation.IdType;import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException;import com.baomidou.mybatisplus.core.toolkit.StringPool;import com.baomidou.mybatisplus.core.toolkit.StringUtils;import com.baomidou.mybatisplus.generator.AutoGenerator;import com.baomidou.mybatisplus.generator.InjectionConfig;import com.baomidou.mybatisplus.generator.config.*;import com.baomidou.mybatisplus.generator.config.po.TableInfo;import com.baomidou.mybatisplus.generator.config.rules.DateType;import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;import com.sun.javafx.PlatformUtil;import java.time.LocalDateTime;import java.time.format.DateTimeFormatter;import java.util.*;public class CodeGenerator { /** * 代码生成位置 */ public static final String PARENT_NAME = "com.miaoying.generator.modulardb"; /** * modular 名字 */ public static final String MODULAR_NAME = ""; /** * 基本路径 */ public static final String SRC_MAIN_JAVA = "src/main/java/"; /** * 作者 */ public static final String AUTHOR = "CodeGenerator"; /** * 是否是 rest 接口 */ private static final boolean REST_CONTROLLER_STYLE = true; public static final String JDBC_MYSQL_URL = "jdbc:mysql://localhost:3306/garbagesort&#63;" + "serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf8"; public static final String JDBC_DRIVER_NAME = "com.mysql.cj.jdbc.Driver"; public static final String JDBC_USERNAME = "root"; public static final String JDBC_PASSWORD = "123456"; public static void main(String[] args) { String moduleName = scanner("模块名"); String tableName = scanner("表名"); String tablePrefix = scanner("表前缀(无前缀输入#)").replaceAll("#", ""); autoGenerator(moduleName, tableName, tablePrefix); } public static void autoGenerator(String moduleName, String tableName, String tablePrefix) { new AutoGenerator() .setGlobalConfig(getGlobalConfig()) .setDataSource(getDataSourceConfig()) .setPackageInfo(getPackageConfig(moduleName)) .setStrategy(getStrategyConfig(tableName, tablePrefix)) .setCfg(getInjectionConfig(moduleName)) .setTemplate(getTemplateConfig()) .execute(); } private static String getDateTime() { LocalDateTime localDate = LocalDateTime.now(); DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"); return localDate.format(formatter); } private static InjectionConfig getInjectionConfig(final String moduleName) { return new InjectionConfig() { @Override public void initMap() { Map map = new HashMap(); map.put("dateTime", getDateTime()); setMap(map); final String projectPath = System.getProperty("user.dir"); List<FileOutConfig> fileOutConfigList = new ArrayList<FileOutConfig>(); // 自定义配置会被优先输出 fileOutConfigList.add(new FileOutConfig("/templates/mapper.xml.vm") { @Override public String outputFile(TableInfo tableInfo) { // 自定义输出文件名,如果entity设置了前后缀,此次注意xml的名称也会跟着发生变化 return projectPath + "/src/main/resources/mapper/" + moduleName + "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML; } }); setFileOutConfigList(fileOutConfigList); } }; } private static StrategyConfig getStrategyConfig(String tableName, String tablePrefix) { return new StrategyConfig() .setNaming(NamingStrategy.underline_to_camel) .setColumnNaming(NamingStrategy.underline_to_camel) .setInclude(tableName) .setRestControllerStyle(REST_CONTROLLER_STYLE) .setEntityBuilderModel(true) .setControllerMappingHyphenStyle(true) .entityTableFieldAnnotationEnable(true) .setTablePrefix(tablePrefix + "_"); } private static PackageConfig getPackageConfig(String moduleName) { return new PackageConfig() .setModuleName(moduleName) .setParent(PARENT_NAME) .setService("service") .setServiceImpl("service.impl") .setController("controller") .setEntity("entity"); } private static DataSourceConfig getDataSourceConfig() { return new DataSourceConfig() .setUrl(JDBC_MYSQL_URL) .setDriverName(JDBC_DRIVER_NAME) .setUsername(JDBC_USERNAME) .setPassword(JDBC_PASSWORD); } private static GlobalConfig getGlobalConfig() { String projectPath = System.getProperty("user.dir"); String filePath = projectPath + "/" + MODULAR_NAME + SRC_MAIN_JAVA; if (PlatformUtil.isWindows()) { filePath = filePath.replaceAll("/+|\\\\+", "\\\\"); } else { filePath = filePath.replaceAll("/+|\\\\+", "/"); } return new GlobalConfig() .setOutputDir(filePath) .setDateType(DateType.ONLY_DATE) .setIdType(IdType.UUID) .setAuthor(AUTHOR) .setBaseColumnList(true) .setSwagger2(true) .setEnableCache(false) .setBaseResultMap(true) .setOpen(false); } private static TemplateConfig getTemplateConfig() { return new TemplateConfig() .setController("/templates-generator/controller.java.vm") .setService("/templates-generator/service.java.vm") .setServiceImpl("/templates-generator/serviceImpl.java.vm") .setEntity("/templates-generator/entity.java.vm") .setMapper("/templates-generator/mapper.java.vm") .setXml("/templates-generator/mapper.xml.vm"); } private static String scanner(String tip) { Scanner scanner = new Scanner(System.in); StringBuilder sb = new StringBuilder(); sb.append("please input " + tip + " : "); System.out.println(sb.toString()); if (scanner.hasNext()) { String ipt = scanner.next(); if (StringUtils.isNotEmpty(ipt)) { return ipt; } } throw new MybatisPlusException("please input the correct " + tip + ". "); }}

4. 执行CodeGenerator.java 里面的 main 方法,根据个人数据库表的配置与期望的工程目录的配置,依次输入模块名、表名、表前缀,比如我的数据库里面有张表叫做: header_click,执行 main 方法时,根据提示依次输入如下:header、header_click、#,最终会在项目工程目录里新增对应的自动生成的文件:

执行 main 方法时,控制台的日志输出如下:

please input 模块名 : headerplease input 表名 : header_clickplease input 表前缀(无前缀输入#) : #13:16:09.416 [main] DEBUG com.baomidou.mybatisplus.generator.AutoGenerator - ==========================准备生成文件...==========================13:16:10.321 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 创建目录: [D:\my-projects\generator-demo\src\main\java\com\miaoying\generator\modulardb\header\entity]13:16:10.321 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 创建目录: [D:\my-projects\generator-demo\src\main\java\com\miaoying\generator\modulardb\header\controller]13:16:10.323 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 创建目录: [D:\my-projects\generator-demo\src\main\java\com\miaoying\generator\modulardb\header\mapper\xml]13:16:10.323 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 创建目录: [D:\my-projects\generator-demo\src\main\java\com\miaoying\generator\modulardb\header\service]13:16:10.323 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 创建目录: [D:\my-projects\generator-demo\src\main\java\com\miaoying\generator\modulardb\header\service\impl]13:16:10.328 [main] DEBUG org.apache.velocity - Initializing Velocity, Calling init()...13:16:10.328 [main] DEBUG org.apache.velocity - Starting Apache Velocity v2.013:16:10.331 [main] DEBUG org.apache.velocity - Default Properties resource: org/apache/velocity/runtime/defaults/velocity.properties13:16:10.352 [main] DEBUG org.apache.velocity - ResourceLoader instantiated: org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader13:16:10.353 [main] DEBUG org.apache.velocity - initialized (class org.apache.velocity.runtime.resource.ResourceCacheImpl) with class java.util.Collections$SynchronizedMap cache map.13:16:10.355 [main] DEBUG org.apache.velocity - Loaded System Directive: org.apache.velocity.runtime.directive.Stop13:16:10.355 [main] DEBUG org.apache.velocity - Loaded System Directive: org.apache.velocity.runtime.directive.Define13:16:10.356 [main] DEBUG org.apache.velocity - Loaded System Directive: org.apache.velocity.runtime.directive.Break13:16:10.356 [main] DEBUG org.apache.velocity - Loaded System Directive: org.apache.velocity.runtime.directive.Evaluate13:16:10.357 [main] DEBUG org.apache.velocity - Loaded System Directive: org.apache.velocity.runtime.directive.Macro13:16:10.358 [main] DEBUG org.apache.velocity - Loaded System Directive: org.apache.velocity.runtime.directive.Parse13:16:10.359 [main] DEBUG org.apache.velocity - Loaded System Directive: org.apache.velocity.runtime.directive.Include13:16:10.359 [main] DEBUG org.apache.velocity - Loaded System Directive: org.apache.velocity.runtime.directive.Foreach13:16:10.373 [main] DEBUG org.apache.velocity.parser - Created '20' parsers.13:16:10.383 [main] DEBUG org.apache.velocity.macro - "velocimacro.library" is not set. Trying default library: VM_global_library.vm13:16:10.383 [main] DEBUG org.apache.velocity.loader.file - Could not load resource 'VM_global_library.vm' from ResourceLoader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader13:16:10.383 [main] DEBUG org.apache.velocity.macro - Default library not found.13:16:10.383 [main] DEBUG org.apache.velocity.macro - allowInline = true: VMs can be defined inline in templates13:16:10.383 [main] DEBUG org.apache.velocity.macro - allowInlineToOverride = false: VMs defined inline may NOT replace previous VM definitions13:16:10.383 [main] DEBUG org.apache.velocity.macro - allowInlineLocal = false: VMs defined inline will be global in scope if allowed.13:16:10.383 [main] DEBUG org.apache.velocity.macro - autoload off: VM system will not automatically reload global library macros13:16:10.394 [main] DEBUG org.apache.velocity.loader - ResourceManager: found /templates/mapper.xml.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader13:16:10.396 [main] DEBUG org.apache.velocity.rendering - =================================================================13:16:10.396 [main] DEBUG org.apache.velocity.rendering - == Class: class java.util.HashMap13:16:10.397 [main] DEBUG org.apache.velocity.rendering - Reflecting class java.util.HashMap13:16:10.399 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object java.util.HashMap.remove(java.lang.Object)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.util.HashMap.remove(java.lang.Object,java.lang.Object)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object java.util.HashMap.get(java.lang.Object)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object java.util.HashMap.put(java.lang.Object,java.lang.Object)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public java.util.Collection java.util.HashMap.values()13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object java.util.HashMap.clone()13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public void java.util.HashMap.clear()13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.util.HashMap.isEmpty()13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.util.HashMap.replace(java.lang.Object,java.lang.Object,java.lang.Object)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object java.util.HashMap.replace(java.lang.Object,java.lang.Object)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public void java.util.HashMap.replaceAll(java.util.function.BiFunction)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public int java.util.HashMap.size()13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public java.util.Set java.util.HashMap.entrySet()13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public void java.util.HashMap.putAll(java.util.Map)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object java.util.HashMap.putIfAbsent(java.lang.Object,java.lang.Object)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public java.util.Set java.util.HashMap.keySet()13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object java.util.HashMap.compute(java.lang.Object,java.util.function.BiFunction)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object java.util.HashMap.computeIfAbsent(java.lang.Object,java.util.function.Function)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object java.util.HashMap.computeIfPresent(java.lang.Object,java.util.function.BiFunction)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.util.HashMap.containsKey(java.lang.Object)13:16:10.400 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.util.HashMap.containsValue(java.lang.Object)13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Adding public void java.util.HashMap.forEach(java.util.function.BiConsumer)13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object java.util.HashMap.getOrDefault(java.lang.Object,java.lang.Object)13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object java.util.HashMap.merge(java.lang.Object,java.lang.Object,java.util.function.BiFunction)13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Reflecting interface java.util.Map13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Adding public abstract boolean java.util.Map.equals(java.lang.Object)13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Adding public abstract int java.util.Map.hashCode()13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Reflecting interface java.lang.Cloneable13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Reflecting interface java.io.Serializable13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Reflecting class java.util.AbstractMap13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.util.AbstractMap.toString()13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Reflecting interface java.util.Map13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Reflecting class java.lang.Object13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Adding public final void java.lang.Object.wait() throws java.lang.InterruptedException13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Adding public final void java.lang.Object.wait(long,int) throws java.lang.InterruptedException13:16:10.401 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.wait(long) throws java.lang.InterruptedException13:16:10.402 [main] DEBUG org.apache.velocity.rendering - Adding public final native java.lang.Class java.lang.Object.getClass()13:16:10.402 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.notify()13:16:10.402 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.notifyAll()13:16:10.402 [main] DEBUG org.apache.velocity.rendering - =================================================================13:16:10.404 [main] DEBUG org.apache.velocity.rendering - =================================================================13:16:10.404 [main] DEBUG org.apache.velocity.rendering - == Class: class com.baomidou.mybatisplus.generator.config.po.TableInfo13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Reflecting class com.baomidou.mybatisplus.generator.config.po.TableInfo13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableInfo.getName()13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public java.util.List com.baomidou.mybatisplus.generator.config.po.TableInfo.getFields()13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableInfo.setName(java.lang.String)13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableInfo.setComment(java.lang.String)13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableInfo.getComment()13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public boolean com.baomidou.mybatisplus.generator.config.po.TableInfo.isConvert()13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public boolean com.baomidou.mybatisplus.generator.config.po.TableInfo.isLogicDelete(java.lang.String)13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableInfo.getServiceName()13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableInfo.getEntityPath()13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableInfo.getEntityName()13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableInfo.getMapperName()13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableInfo.getXmlName()13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableInfo.setImportPackages(java.lang.String)13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableInfo.getServiceImplName()13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableInfo.getControllerName()13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableInfo.setFields(java.util.List)13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableInfo.setControllerName(java.lang.String)13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableInfo.setServiceImplName(java.lang.String)13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableInfo.setXmlName(java.lang.String)13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableInfo.setEntityName(com.baomidou.mybatisplus.generator.config.StrategyConfig,java.lang.String)13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableInfo.setServiceName(java.lang.String)13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableInfo.setMapperName(java.lang.String)13:16:10.404 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableInfo.setCommonFields(java.util.List)13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public java.util.Set com.baomidou.mybatisplus.generator.config.po.TableInfo.getImportPackages()13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public java.util.List com.baomidou.mybatisplus.generator.config.po.TableInfo.getCommonFields()13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableInfo.getFieldNames()13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableInfo.setConvert(boolean)13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Reflecting class java.lang.Object13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public final void java.lang.Object.wait() throws java.lang.InterruptedException13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public final void java.lang.Object.wait(long,int) throws java.lang.InterruptedException13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.wait(long) throws java.lang.InterruptedException13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.Object.equals(java.lang.Object)13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.Object.toString()13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public native int java.lang.Object.hashCode()13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public final native java.lang.Class java.lang.Object.getClass()13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.notify()13:16:10.405 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.notifyAll()13:16:10.405 [main] DEBUG org.apache.velocity.rendering - =================================================================13:16:10.406 [main] DEBUG org.apache.velocity.rendering - =================================================================13:16:10.406 [main] DEBUG org.apache.velocity.rendering - == Class: class com.baomidou.mybatisplus.generator.config.po.TableField13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Reflecting class com.baomidou.mybatisplus.generator.config.po.TableField13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableField.getName()13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableField.setName(java.lang.String)13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableField.getType()13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableField.setComment(java.lang.String)13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableField.getComment()13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableField.getPropertyType()13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public boolean com.baomidou.mybatisplus.generator.config.po.TableField.isConvert()13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableField.getPropertyName()13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableField.setPropertyName(com.baomidou.mybatisplus.generator.config.StrategyConfig,java.lang.String)13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableField.setKeyFlag(boolean)13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableField.setType(java.lang.String)13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableField.setColumnType(com.baomidou.mybatisplus.generator.config.rules.PropertyInfo)13:16:10.406 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableField.setCustomMap(java.util.Map)13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableField.setFill(java.lang.String)13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableField.setKeyIdentityFlag(boolean)13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public com.baomidou.mybatisplus.generator.config.rules.PropertyInfo com.baomidou.mybatisplus.generator.config.po.TableField.getColumnType()13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableField.getCapitalName()13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public boolean com.baomidou.mybatisplus.generator.config.po.TableField.isKeyFlag()13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public void com.baomidou.mybatisplus.generator.config.po.TableField.setConvert(boolean)13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String com.baomidou.mybatisplus.generator.config.po.TableField.getFill()13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public boolean com.baomidou.mybatisplus.generator.config.po.TableField.isKeyIdentityFlag()13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public java.util.Map com.baomidou.mybatisplus.generator.config.po.TableField.getCustomMap()13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Reflecting class java.lang.Object13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public final void java.lang.Object.wait() throws java.lang.InterruptedException13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public final void java.lang.Object.wait(long,int) throws java.lang.InterruptedException13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.wait(long) throws java.lang.InterruptedException13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.Object.equals(java.lang.Object)13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.Object.toString()13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public native int java.lang.Object.hashCode()13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public final native java.lang.Class java.lang.Object.getClass()13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.notify()13:16:10.407 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.notifyAll()13:16:10.407 [main] DEBUG org.apache.velocity.rendering - =================================================================13:16:10.412 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates/mapper.xml.vm; 文件:D:\my-projects\generator-demo/src/main/resources/mapper/header/HeaderClickMapper.xml13:16:10.435 [main] DEBUG org.apache.velocity.loader - ResourceManager: found /templates-generator/entity.java.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader13:16:10.437 [main] DEBUG org.apache.velocity.rendering - =================================================================13:16:10.438 [main] DEBUG org.apache.velocity.rendering - == Class: class java.lang.String13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Reflecting class java.lang.String13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.String.equals(java.lang.Object)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.toString()13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.hashCode()13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.compareTo(java.lang.String)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.compareTo(java.lang.Object)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.indexOf(java.lang.String,int)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.indexOf(java.lang.String)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.indexOf(int,int)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.indexOf(int)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.valueOf(int)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.valueOf(long)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.valueOf(float)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.valueOf(boolean)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.valueOf(char[])13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.valueOf(char[],int,int)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.valueOf(java.lang.Object)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.valueOf(char)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.valueOf(double)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public char java.lang.String.charAt(int)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.codePointAt(int)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.codePointBefore(int)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.codePointCount(int,int)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.compareToIgnoreCase(java.lang.String)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.concat(java.lang.String)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.String.contains(java.lang.CharSequence)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.String.contentEquals(java.lang.CharSequence)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.String.contentEquals(java.lang.StringBuffer)13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.copyValueOf(char[])13:16:10.438 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.copyValueOf(char[],int,int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.String.endsWith(java.lang.String)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.String.equalsIgnoreCase(java.lang.String)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.format(java.util.Locale,java.lang.String,java.lang.Object[])13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.format(java.lang.String,java.lang.Object[])13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public void java.lang.String.getBytes(int,int,byte[],int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public byte[] java.lang.String.getBytes(java.nio.charset.Charset)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public byte[] java.lang.String.getBytes(java.lang.String) throws java.io.UnsupportedEncodingException13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public byte[] java.lang.String.getBytes()13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public void java.lang.String.getChars(int,int,char[],int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public native java.lang.String java.lang.String.intern()13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.String.isEmpty()13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.join(java.lang.CharSequence,java.lang.CharSequence[])13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public static java.lang.String java.lang.String.join(java.lang.CharSequence,java.lang.Iterable)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.lastIndexOf(int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.lastIndexOf(java.lang.String)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.lastIndexOf(java.lang.String,int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.lastIndexOf(int,int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.length()13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.String.matches(java.lang.String)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public int java.lang.String.offsetByCodePoints(int,int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.String.regionMatches(int,java.lang.String,int,int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.String.regionMatches(boolean,int,java.lang.String,int,int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.replace(char,char)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.replace(java.lang.CharSequence,java.lang.CharSequence)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.replaceAll(java.lang.String,java.lang.String)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.replaceFirst(java.lang.String,java.lang.String)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String[] java.lang.String.split(java.lang.String)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String[] java.lang.String.split(java.lang.String,int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.String.startsWith(java.lang.String,int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.lang.String.startsWith(java.lang.String)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.CharSequence java.lang.String.subSequence(int,int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.substring(int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.substring(int,int)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public char[] java.lang.String.toCharArray()13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.toLowerCase(java.util.Locale)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.toLowerCase()13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.toUpperCase()13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.toUpperCase(java.util.Locale)13:16:10.441 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.lang.String.trim()13:16:10.442 [main] DEBUG org.apache.velocity.rendering - Reflecting interface java.io.Serializable13:16:10.442 [main] DEBUG org.apache.velocity.rendering - Reflecting interface java.lang.Comparable13:16:10.442 [main] DEBUG org.apache.velocity.rendering - Reflecting interface java.lang.CharSequence13:16:10.442 [main] DEBUG org.apache.velocity.rendering - Adding public default java.util.stream.IntStream java.lang.CharSequence.chars()13:16:10.442 [main] DEBUG org.apache.velocity.rendering - Adding public default java.util.stream.IntStream java.lang.CharSequence.codePoints()13:16:10.442 [main] DEBUG org.apache.velocity.rendering - Reflecting class java.lang.Object13:16:10.442 [main] DEBUG org.apache.velocity.rendering - Adding public final void java.lang.Object.wait() throws java.lang.InterruptedException13:16:10.442 [main] DEBUG org.apache.velocity.rendering - Adding public final void java.lang.Object.wait(long,int) throws java.lang.InterruptedException13:16:10.442 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.wait(long) throws java.lang.InterruptedException13:16:10.442 [main] DEBUG org.apache.velocity.rendering - Adding public final native java.lang.Class java.lang.Object.getClass()13:16:10.442 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.notify()13:16:10.442 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.notifyAll()13:16:10.442 [main] DEBUG org.apache.velocity.rendering - =================================================================13:16:10.444 [main] DEBUG org.apache.velocity.rendering - =================================================================13:16:10.444 [main] DEBUG org.apache.velocity.rendering - == Class: class org.apache.velocity.runtime.directive.ForeachScope13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Reflecting class org.apache.velocity.runtime.directive.ForeachScope13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public boolean org.apache.velocity.runtime.directive.ForeachScope.hasNext()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public boolean org.apache.velocity.runtime.directive.ForeachScope.getFirst()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public boolean org.apache.velocity.runtime.directive.ForeachScope.getLast()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public int org.apache.velocity.runtime.directive.ForeachScope.getIndex()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public int org.apache.velocity.runtime.directive.ForeachScope.getCount()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public boolean org.apache.velocity.runtime.directive.ForeachScope.isLast()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public boolean org.apache.velocity.runtime.directive.ForeachScope.isFirst()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public boolean org.apache.velocity.runtime.directive.ForeachScope.getHasNext()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Reflecting class org.apache.velocity.runtime.directive.Scope13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object org.apache.velocity.runtime.directive.Scope.get(java.lang.Object)13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object org.apache.velocity.runtime.directive.Scope.put(java.lang.Object,java.lang.Object)13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public java.util.Set org.apache.velocity.runtime.directive.Scope.entrySet()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public org.apache.velocity.runtime.directive.Scope org.apache.velocity.runtime.directive.Scope.getParent()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String org.apache.velocity.runtime.directive.Scope.set(java.lang.Object,java.lang.Object)13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public org.apache.velocity.runtime.directive.Scope$Info org.apache.velocity.runtime.directive.Scope.getInfo()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public org.apache.velocity.runtime.directive.Scope org.apache.velocity.runtime.directive.Scope.getTopmost()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object org.apache.velocity.runtime.directive.Scope.getReplaced()13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Reflecting class java.util.AbstractMap13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.Object java.util.AbstractMap.remove(java.lang.Object)13:16:10.445 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.util.AbstractMap.equals(java.lang.Object)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public java.lang.String java.util.AbstractMap.toString()13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public java.util.Collection java.util.AbstractMap.values()13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public int java.util.AbstractMap.hashCode()13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public void java.util.AbstractMap.clear()13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.util.AbstractMap.isEmpty()13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public int java.util.AbstractMap.size()13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public void java.util.AbstractMap.putAll(java.util.Map)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public java.util.Set java.util.AbstractMap.keySet()13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.util.AbstractMap.containsKey(java.lang.Object)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public boolean java.util.AbstractMap.containsValue(java.lang.Object)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Reflecting interface java.util.Map13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public default boolean java.util.Map.remove(java.lang.Object,java.lang.Object)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public default java.lang.Object java.util.Map.replace(java.lang.Object,java.lang.Object)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public default boolean java.util.Map.replace(java.lang.Object,java.lang.Object,java.lang.Object)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public default void java.util.Map.replaceAll(java.util.function.BiFunction)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public default java.lang.Object java.util.Map.putIfAbsent(java.lang.Object,java.lang.Object)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public default java.lang.Object java.util.Map.compute(java.lang.Object,java.util.function.BiFunction)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public default java.lang.Object java.util.Map.computeIfAbsent(java.lang.Object,java.util.function.Function)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public default java.lang.Object java.util.Map.computeIfPresent(java.lang.Object,java.util.function.BiFunction)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public default void java.util.Map.forEach(java.util.function.BiConsumer)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public default java.lang.Object java.util.Map.getOrDefault(java.lang.Object,java.lang.Object)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public default java.lang.Object java.util.Map.merge(java.lang.Object,java.lang.Object,java.util.function.BiFunction)13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Reflecting class java.lang.Object13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public final void java.lang.Object.wait() throws java.lang.InterruptedException13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public final void java.lang.Object.wait(long,int) throws java.lang.InterruptedException13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.wait(long) throws java.lang.InterruptedException13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public final native java.lang.Class java.lang.Object.getClass()13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.notify()13:16:10.446 [main] DEBUG org.apache.velocity.rendering - Adding public final native void java.lang.Object.notifyAll()13:16:10.446 [main] DEBUG org.apache.velocity.rendering - =================================================================13:16:10.449 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates-generator/entity.java.vm; 文件:D:\my-projects\generator-demo\src\main\java\com\miaoying\generator\modulardb\header\entity\HeaderClick.java13:16:10.451 [main] DEBUG org.apache.velocity.loader - ResourceManager: found /templates-generator/mapper.java.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader13:16:10.453 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates-generator/mapper.java.vm; 文件:D:\my-projects\generator-demo\src\main\java\com\miaoying\generator\modulardb\header\mapper\HeaderClickMapper.java13:16:10.461 [main] DEBUG org.apache.velocity.loader - ResourceManager: found /templates-generator/mapper.xml.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader13:16:10.465 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates-generator/mapper.xml.vm; 文件:D:\my-projects\generator-demo\src\main\java\com\miaoying\generator\modulardb\header\mapper\xml\HeaderClickMapper.xml13:16:10.467 [main] DEBUG org.apache.velocity.loader - ResourceManager: found /templates-generator/service.java.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader13:16:10.469 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates-generator/service.java.vm; 文件:D:\my-projects\generator-demo\src\main\java\com\miaoying\generator\modulardb\header\service\IHeaderClickService.java13:16:10.482 [main] DEBUG org.apache.velocity.loader - ResourceManager: found /templates-generator/serviceImpl.java.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader13:16:10.484 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates-generator/serviceImpl.java.vm; 文件:D:\my-projects\generator-demo\src\main\java\com\miaoying\generator\modulardb\header\service\impl\HeaderClickServiceImpl.java13:16:10.496 [main] DEBUG org.apache.velocity.loader - ResourceManager: found /templates-generator/controller.java.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader13:16:10.498 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates-generator/controller.java.vm; 文件:D:\my-projects\generator-demo\src\main\java\com\miaoying\generator\modulardb\header\controller\HeaderClickController.java13:16:10.498 [main] DEBUG com.baomidou.mybatisplus.generator.AutoGenerator - ==========================文件生成完成!!!==========================Process finished with exit code 0

上述内容就是怎么用mybatis-plus-generator实现代码自动生成,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。