IDEAプラグインEasyCodeとMyBatisの最適な構成手順詳細


具体的なインストールの手順は、これ以上説明しないで、ただ個人の仕事、学習の中のEasyCodeに対する詳しい配置だけを添付します。
プラグインのリンク先:https://gitee.com/makejava/EasyCode
Type Mapper

varchar(\(\d+\))?										java.lang.String
char(\(\d+\))?											java.lang.String
text													java.lang.String
decimal(\(\d+\))?										java.lang.Double
decimal(\(\d+,\d+\))?									java.lang.Double
integer													java.lang.Integer
int(\(\d+\))?											java.lang.Integer
int4													java.lang.Integer
int8													java.lang.Long
bigint(\(\d+\))?										java.lang.Long
datetime(\(\d+\))?										java.time.LocalDateTime
timestamp												java.time.LocalDateTime
boolean													java.lang.Boolean
tinyint(\(\d+\))?										java.lang.Integer
smallint(\(\d+\))?										java.lang.Integer
double(\(\d+\))?										java.lang.Double
double(\(\d+,\d+\))?									java.lang.Double
Template Setting
entity.java

##     
$!init
##     
$!define

##         (         )
#save("/entity", ".java")

##          
#setPackageSuffix("entity")

##             
$!autoImport
import java.io.Serializable;

##            
#tableComment("   ")
public class $!{tableInfo.name} implements Serializable {

 private static final long serialVersionUID = $!tool.serial();
 #foreach($column in $tableInfo.fullColumn)
 #if(${column.comment})/**
 * ${column.comment}
 */#end

 private $!{tool.getClsNameByFullName($column.type)} $!{column.name};
 #end
 
 public $!{tableInfo.name}() {
 }
 
 public $!{tableInfo.name}(#foreach($column in $tableInfo.fullColumn)$!{tool.getClsNameByFullName($column.type)} $!column.name #if($velocityCount != $tableInfo.fullColumn.size()), #end#end) {
 #foreach($column in $tableInfo.fullColumn) this.$!column.name = $!column.name;#end
 
 }
#foreach($column in $tableInfo.fullColumn)
##       get,set  
 #getSetMethod($column)
#end

 @Override
 public String toString() { 
 StringBuilder str = new StringBuilder();
 str.append("$!{tableInfo.name}{"); 
 #foreach( $column in $tableInfo.fullColumn )
 str.append("$!column.name=").append(this.$!column.name)#if( $foreach.hasNext ).append(", ")#end;
 #end
 str.append('}'); 
 return str.toString();
 }

}
DUTO.java

##     
$!define

##    (   )
#save("/dto", "DTO.java")

##   (   )
#setPackageSuffix("dto")

##     (    )
$!autoImport
##import com.baomidou.mybatisplus.extension.activerecord.Model;
import java.io.Serializable;
import lombok.Data;
##import com.baomidou.mybatisplus.annotation.IdType;
##import com.baomidou.mybatisplus.annotation.TableId;

##   (   )
#tableComment("DTO")
@Data
public class $!{tableInfo.name}DTO implements Serializable {

 private static final long serialVersionUID = $!tool.serial();
#foreach($column in $tableInfo.fullColumn)
 #if(${column.comment})/**${column.comment}*/#end

 private $!{tool.getClsNameByFullName($column.type)} $!{column.name};
#end

}
mapper.java

##      
#set($tableName = $tool.append($tableInfo.name, "Mapper"))
##    
$!callback.setFileName($tool.append($tableName, ".java"))
$!callback.setSavePath($tool.append($tableInfo.savePath, "/mapper"))

##    
#if(!$tableInfo.pkColumn.isEmpty())
 #set($pk = $tableInfo.pkColumn.get(0))
#end

#if($tableInfo.savePackageName)package $!{tableInfo.savePackageName}.#{end}mapper;

import $!{tableInfo.savePackageName}.entity.$!{tableInfo.name};
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.util.List;

#set($time=$!time.currTime())
#set($time=$time.substring(0,11))
#set($time=$time.replace("-","/"))
/**
 * <p>
 * $!{tableInfo.comment}($!{tableInfo.name})       
 * </p>
 * 
 * @author:$!author
 * @date:$!time
 */
@Mapper
public interface $!{tableName} {

 /**
 *   ID      
 *
 * @param $!pk.name   
 * @return     
 */
 $!{tableInfo.name} queryById($!pk.shortType $!pk.name);

 /**
 *             
 *
 * @param $!tool.firstLowerCase($!{tableInfo.name})     
 * @return     
 */
 List<$!{tableInfo.name}> queryAll($!{tableInfo.name} $!tool.firstLowerCase($!{tableInfo.name}));
 
 /**
 *               
 *
 * @param $!tool.firstLowerCase($!{tableInfo.name})     
 * @return   
 */
 int queryAllCount($!{tableInfo.name} $!tool.firstLowerCase($!{tableInfo.name}));

 /**
 *     
 *
 * @param $!tool.firstLowerCase($!{tableInfo.name})     
 * @return     
 */
 int insert($!{tableInfo.name} $!tool.firstLowerCase($!{tableInfo.name}));

 /**
 *      
 *
 * @param $!tool.firstLowerCase($!{tableInfo.name})     
 * @return     
 */
 int insertSelective($!{tableInfo.name} $!tool.firstLowerCase($!{tableInfo.name}));
 
 /**
 *     
 *
 * @param $!tool.firstLowerCase($!{tableInfo.name})     
 * @return     
 */
 int update($!{tableInfo.name} $!tool.firstLowerCase($!{tableInfo.name}));

 /**
 *         
 *
 * @param $!pk.name   
 * @return     
 */
 int deleteById($!pk.shortType $!pk.name);
 
 /**
 *     
 * @param recordList
 * @return     
 */
 int batchInsert(@Param("recordList") List<$!{tableInfo.name}> recordList);
 
 /**
 *     
 * @param recordList 
 * @return     
 */
 int batchUpdate(@Param("recordList") List<$!{tableInfo.name}> recordList);
 
 /**
 *         
 * @param ids   s
 * @return     
 */
 int batchDelete(@Param("ids") String[] ids);
 
}
serviceImpl.java

##     
$!init
##      
#set($tableName = $tool.append($tableInfo.name, "ServiceImpl"))
##    
$!callback.setFileName($tool.append($tableName, ".java"))
$!callback.setSavePath($tool.append($tableInfo.savePath, "/service/impl"))

##    
#if(!$tableInfo.pkColumn.isEmpty())
 #set($pk = $tableInfo.pkColumn.get(0))
#end

#if($tableInfo.savePackageName)package $!{tableInfo.savePackageName}.#{end}service.impl;

import $!{tableInfo.savePackageName}.mapper.$!{tableInfo.name}Mapper;
import $!{tableInfo.savePackageName}.service.$!{tableInfo.name}Service;
import org.springframework.stereotype.Service;
import org.springframework.beans.factory.annotation.Autowired;

#set($time=$!time.currTime())
#set($time=$time.substring(0,11))
#set($time=$time.replace("-","/"))
/**
 * <p>
 * $!{tableInfo.comment}($!{tableInfo.name})      
 * </p>
 * 
 * @author:$!author
 * @date:$!time
 */
@Service("/$!tool.firstLowerCase($!{tableInfo.name})Service")
public class $!{tableName} implements $!{tableInfo.name}Service {

 @Autowired
 private $!{tableInfo.name}Mapper $!tool.firstLowerCase($!{tableInfo.name})Mapper;

}
service.java

##      
#set($tableName = $tool.append($tableInfo.name, "Service"))
##    
$!callback.setFileName($tool.append($tableName, ".java"))
$!callback.setSavePath($tool.append($tableInfo.savePath, "/service"))

##    
#if(!$tableInfo.pkColumn.isEmpty())
 #set($pk = $tableInfo.pkColumn.get(0))
#end

#if($tableInfo.savePackageName)package $!{tableInfo.savePackageName}.#{end}service;

#set($time=$!time.currTime())
#set($time=$time.substring(0,11))
#set($time=$time.replace("-","/"))
/**
 * <p>
 * $!{tableInfo.comment}($!{tableInfo.name})     
 * </p>
 * 
 * @author:$!author
 * @date:$!time
 */
public interface $!{tableName} {

}
controller.java

##      
#set($tableName = $tool.append($tableInfo.name, "Controller"))
##    
$!callback.setFileName($tool.append($tableName, ".java"))
$!callback.setSavePath($tool.append($tableInfo.savePath, "/controller"))
##    
#if(!$tableInfo.pkColumn.isEmpty())
 #set($pk = $tableInfo.pkColumn.get(0))
#end

#if($tableInfo.savePackageName)package $!{tableInfo.savePackageName}.#{end}controller;

import $!{tableInfo.savePackageName}.service.$!{tableInfo.name}Service;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

#set($time=$!time.currTime())
#set($time=$time.substring(0,11))
#set($time=$time.replace("-","/"))
/**
 * <p>
 * $!{tableInfo.comment}($!{tableInfo.name})    
 * </p>
 * 
 * @author:$!author
 * @date:$!time
 */
@RestController
@RequestMapping("/$!tool.firstLowerCase($tableInfo.name)")
public class $!{tableName} {

 @Autowired
 private $!{tableInfo.name}Service $!tool.firstLowerCase($tableInfo.name)Service;

}
mysql-mapper.xml

##  mybatis  
$!mybatisSupport

##           
$!callback.setFileName($tool.append($!{tableInfo.name}, "Mapper.xml"))
$!callback.setSavePath($tool.append($modulePath, "/src/main/resources/mapper"))

##    
#if(!$tableInfo.pkColumn.isEmpty())
 #set($pk = $tableInfo.pkColumn.get(0))
#end

<?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="$!{tableInfo.savePackageName}.mapper.$!{tableInfo.name}Mapper">

 <resultMap type="$!{tableInfo.savePackageName}.entity.$!{tableInfo.name}" id="$!{tableInfo.name}Map">
#foreach($column in $tableInfo.fullColumn)
 <result property="$!column.name" column="$!column.name" jdbcType="$!column.ext.jdbcType"/>
#end
 </resultMap>
	
	<!--    -->
	<sql id="columns">
#foreach($column in $tableInfo.fullColumn)
 a.$!column.obj.name AS $!column.name #if($velocityCount != $tableInfo.fullColumn.size()),#end

#end
 </sql>
 <!--      -->
	<sql id="whereSql">
 <where>
#foreach($column in $tableInfo.fullColumn)
  <if test="$!column.name != null#if($column.type.equals("java.lang.String")) and $!column.name != ''#end">
  and a.$!column.obj.name = #{$!column.name}
  </if>
#end
 </where>
 </sql>
	
 <!--   ID       -->
 <select id="queryById" resultType="$!{tableInfo.savePackageName}.entity.$!{tableInfo.name}">
 select
  <include refid="columns"/>
 from $!{tableInfo.obj.parent.name}.$!tableInfo.obj.name a
 where a.$!pk.obj.name = #{$!pk.name}
 </select>
 
 <!--              -->
 <select id="queryAll" resultType="$!{tableInfo.savePackageName}.entity.$!{tableInfo.name}">
 select
  <include refid="columns"/>
 from $!{tableInfo.obj.parent.name}.$!tableInfo.obj.name a
 <include refid="whereSql" />
 </select>
 
 <!--                -->
 <select id="queryAllCount" resultType="java.lang.Integer">
 select
  count(1)
 from $!{tableInfo.obj.parent.name}.$!tableInfo.obj.name a
 <include refid="whereSql" />
 </select>

 <!--      -->
 <insert id="insert" keyProperty="$!pk.name" useGeneratedKeys="true">
 insert into $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name}(#foreach($column in $tableInfo.fullColumn)$!column.obj.name#if($velocityHasNext), #end#end)
 values (#foreach($column in $tableInfo.fullColumn)#{$!{column.name}}#if($velocityHasNext), #end#end)
 </insert>
 
 <!--       -->
 <insert id="insertSelective" keyProperty="$!pk.name" useGeneratedKeys="true">
 insert into $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name}
 <trim prefix="(" suffix=")" suffixOverrides="," >
#foreach($column in $tableInfo.fullColumn)
  <if test="$!column.name != null#if($column.type.equals("java.lang.String")) and $!column.name != ''#end">
  $!column.obj.name,
  </if>
#end
 </trim>
 <trim prefix="values (" suffix=")" suffixOverrides="," >
#foreach($column in $tableInfo.fullColumn)
  <if test="$!column.name != null#if($column.type.equals("java.lang.String")) and $!column.name != ''#end">
  #{$!column.name,jdbcType=$!column.ext.jdbcType},
  </if>
#end
 </trim>
 </insert>
 
 <!--      -->
 <update id="update">
 update $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name}
 <set>
#foreach($column in $tableInfo.otherColumn)
  <if test="$!column.name != null#if($column.type.equals("java.lang.String")) and $!column.name != ''#end">
  $!column.obj.name = #{$!column.name},
  </if>
#end
 </set>
 where $!pk.obj.name = #{$!pk.name}
 </update>

 <!--          -->
 <delete id="deleteById">
 delete from $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name} where $!pk.obj.name = #{$!pk.name}
 </delete>
 
 <!--      -->
 <insert id="batchInsert" parameterType="java.util.List">
 insert into $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name} (
 #foreach($column in $tableInfo.fullColumn)$!column.obj.name#if($velocityHasNext), #end#end
 
 )
 values
 <foreach collection="recordList" index="index" item="item" separator=",">
 (
 #foreach($column in $tableInfo.fullColumn)#{item.$!{column.name}}#if($velocityHasNext), #end#end
 
 )
 </foreach>
 </insert>
 
 <!--      -->
 <update id="batchUpdate" parameterType="java.util.List">
 update $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name} 
 <trim prefix="set" suffixOverrides=",">
#foreach($column in $tableInfo.otherColumn)
 <trim prefix="$!column.obj.name =case $!pk.obj.name" suffix="end,">
 <foreach collection="recordList" index="index" item="item">
  <if test="item.$!column.name !=null ">
  when #{item.$!pk.name} then #{item.$!column.name}
  </if>
  <if test="item.$!column.name ==null ">
  when #{item.$!pk.name} then $!{tableInfo.obj.name}.$!column.obj.name
  </if>
 </foreach>
 </trim>
#end
 </trim>
 where $!pk.obj.name in(
 <foreach collection="recordList" index="index" item="item" separator=",">
 #{item.$!pk.name}
 </foreach>
 )
 </update>
 
 <!--          -->
 <delete id="batchDelete" parameterType="java.lang.String">
 delete from $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name} where $!pk.obj.name in (
 <foreach collection="ids" index="index" item="item" separator=",">
  #{item}
 </foreach>
 )
 </delete>
 
</mapper>
orace-mapper.xml

##  mybatis  
$!mybatisSupport

##           
$!callback.setFileName($tool.append($!{tableInfo.name}, "Mapper.xml"))
$!callback.setSavePath($tool.append($tableInfo.savePath, "/src/main/resources/mapper"))

##    
#if(!$tableInfo.pkColumn.isEmpty())
 #set($pk = $tableInfo.pkColumn.get(0))
#end

<?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="$!{tableInfo.savePackageName}.mapper.$!{tableInfo.name}Mapper">

 <resultMap type="$!{tableInfo.savePackageName}.entity.$!{tableInfo.name}" id="$!{tableInfo.name}Map">
#foreach($column in $tableInfo.fullColumn)
 <result property="$!column.name" column="$!column.name" jdbcType="$!column.ext.jdbcType"/>
#end
 </resultMap>
	
	<!--    -->
	<sql id="columns">
#foreach($column in $tableInfo.fullColumn)
 a.$!column.obj.name AS $!column.name #if($velocityCount != $tableInfo.fullColumn.size()),#end

#end
 </sql>
 <!--      -->
	<sql id="whereSql">
 <where>
#foreach($column in $tableInfo.fullColumn)
  <if test="$!column.name != null#if($column.type.equals("java.lang.String")) and $!column.name != ''#end">
  and a.$!column.obj.name = #{$!column.name}
  </if>
#end
 </where>
 </sql>
 
 <!--   ID       -->
 <select id="queryById" resultType="$!{tableInfo.savePackageName}.entity.$!{tableInfo.name}">
 select
  <include refid="columns"/>
 from $!{tableInfo.obj.parent.name}.$!tableInfo.obj.name a
 where a.$!pk.obj.name = #{$!pk.name}
 </select>
 
 <!--              -->
 <select id="queryAll" resultType="$!{tableInfo.savePackageName}.entity.$!{tableInfo.name}">
 select
  <include refid="columns"/>
 from $!{tableInfo.obj.parent.name}.$!tableInfo.obj.name a
 <include refid="whereSql" />
 </select>
 
 <!--                -->
 <select id="queryAllCount" resultType="java.lang.Integer">
 select
  count(1)
 from $!{tableInfo.obj.parent.name}.$!tableInfo.obj.name a
 <include refid="whereSql" />
 </select>

 <!--      -->
 <insert id="insert" keyProperty="$!pk.name" useGeneratedKeys="true">
 insert into $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name}(#foreach($column in $tableInfo.fullColumn)$!column.obj.name#if($velocityHasNext), #end#end)
 values (#foreach($column in $tableInfo.fullColumn)#{$!{column.name}}#if($velocityHasNext), #end#end)
 </insert>
 
 <!--       -->
 <insert id="insertSelective" keyProperty="$!pk.name" useGeneratedKeys="true">
 insert into $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name}
 <trim prefix="(" suffix=")" suffixOverrides="," >
#foreach($column in $tableInfo.fullColumn)
  <if test="$!column.name != null#if($column.type.equals("java.lang.String")) and $!column.name != ''#end">
  $!column.obj.name,
  </if>
#end
 </trim>
 <trim prefix="values (" suffix=")" suffixOverrides="," >
#foreach($column in $tableInfo.fullColumn)
  <if test="$!column.name != null#if($column.type.equals("java.lang.String")) and $!column.name != ''#end">
  #{$!column.name,jdbcType=$!column.ext.jdbcType},
  </if>
#end
 </trim>
 </insert>
 
 <!--      -->
 <update id="update">
 update $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name}
 <set>
#foreach($column in $tableInfo.otherColumn)
  <if test="$!column.name != null#if($column.type.equals("java.lang.String")) and $!column.name != ''#end">
  $!column.obj.name = #{$!column.name},
  </if>
#end
 </set>
 where $!pk.obj.name = #{$!pk.name}
 </update>
 
 <!--          -->
 <delete id="deleteById">
 delete from $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name} where $!pk.obj.name = #{$!pk.name}
 </delete>
 
 <!--      -->
 <insert id="batchInsert" parameterType="java.util.List">
 insert into $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name} (
 #foreach($column in $tableInfo.fullColumn)$!column.obj.name#if($velocityHasNext), #end#end
 
 )
 (
 <foreach collection="recordList" index="index" item="item" separator=",">
  (
  select
  #foreach($column in $tableInfo.fullColumn)#{item.$!{column.name}}#if($velocityHasNext), #end#end
  
  from dual
  )
 </foreach>
 )
 </insert>
 
 <!--      -->
 <update id="batchUpdate" parameterType="java.util.List">
 begin
 <foreach collection="recordList" index="index" item="item" separator=";">
 update $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name} 
 <set>
#foreach($column in $tableInfo.otherColumn)
 $!column.obj.name = #{item.$!column.name}
#end
 </set>
 where ID = #{item.$!pk.obj.name}
 </foreach>
 ;end;
 </update>
 
 <!--          -->
 <delete id="batchDelete" parameterType="java.lang.String">
 delete from $!{tableInfo.obj.parent.name}.$!{tableInfo.obj.name} where $!pk.obj.name in (
 <foreach collection="ids" index="index" item="item" separator=",">
  #{item}
 </foreach>
 )
 </delete>
 
</mapper>
Global Config
init

##     

##    t_  
#if($tableInfo.obj.name.startsWith("t_"))
 $!tableInfo.setName($tool.getClassName($tableInfo.obj.name.substring(2)))
#end

##          ,POJO          ,     is   ,                
#foreach($column in $tableInfo.fullColumn)
 #if($column.name.startsWith("is") && $column.type.equals("java.lang.Boolean"))
 $!column.setName($tool.firstLowerCase($column.name.substring(2)))
 #end
#end

##       
#set($temp = $tool.newHashSet("testCreateTime", "otherColumn"))
#foreach($item in $temp)
 #set($newList = $tool.newArrayList())
 #foreach($column in $tableInfo.fullColumn)
 #if($column.name!=$item)
 ##             $tool.call      
  $tool.call($newList.add($column))
 #end
 #end
##    
 $tableInfo.setFullColumn($newList)
#end

## importList    
#set($temp = $tool.newHashSet())
#foreach($column in $tableInfo.fullColumn)
 #if(!$column.type.startsWith("java.lang."))
 ##             $tool.call      
 $tool.call($temp.add($column.type))
 #end
#end
##  
#set($importList = $temp)
define

##(Velocity   )

##            ,    :#setTableSuffix("Test")
#macro(setTableSuffix $suffix)
 #set($tableName = $!tool.append($tableInfo.name, $suffix))
#end

##            ,    :#setPackageSuffix("Test")
#macro(setPackageSuffix $suffix)
 #if($suffix!="")package #end#if($tableInfo.savePackageName!="")$!{tableInfo.savePackageName}.#{end}$!suffix;
#end

##                  ,    :#save("/entity", ".java")
#macro(save $path $fileName)
 $!callback.setSavePath($tool.append($tableInfo.savePath, $path))
 $!callback.setFileName($tool.append($tableInfo.name, $fileName))
#end

##         ,    :#tableComment("    ")
#macro(tableComment $desc)
#set($time=$!time.currTime())
#set($time=$time.substring(0,11))
#set($time=$time.replace("-","/"))
/**
 * <p>
 * $!{tableInfo.comment}($!{tableInfo.name})$desc
 * </p>
 * 
 * @author:$!author
 * @date:$!time
 */
#end

##  GET,SET      ,    :#getSetMethod($column)
#macro(getSetMethod $column)

 public $!{tool.getClsNameByFullName($column.type)} get$!{tool.firstUpperCase($column.name)}() {
 return $!{column.name};
 }

 public void set$!{tool.firstUpperCase($column.name)}($!{tool.getClsNameByFullName($column.type)} $!{column.name}) {
 #if(${column.type.equals("java.lang.String")})this.$!{column.name} = $!{column.name}== null ? null : $!{column.name}.trim();
 #else this.$!{column.name} = $!{column.name};#end} 
#end
mybatis Support

##  Mybatis     ,      xml  
#foreach($column in $tableInfo.fullColumn)
 ##     
 $tool.call($column.ext.put("sqlType", $tool.getField($column.obj.dataType, "typeName")))
 #if($tool.newHashSet("java.lang.String").contains($column.type))
 #set($jdbcType="VARCHAR")
 #elseif($tool.newHashSet("java.lang.Boolean", "boolean").contains($column.type))
 #set($jdbcType="BOOLEAN")
 #elseif($tool.newHashSet("java.lang.Byte", "byte").contains($column.type))
 #set($jdbcType="BYTE")
 #elseif($tool.newHashSet("java.lang.Integer", "int", "java.lang.Short", "short").contains($column.type))
 #set($jdbcType="INTEGER")
 #elseif($tool.newHashSet("java.lang.Long", "long").contains($column.type))
 #set($jdbcType="INTEGER")
 #elseif($tool.newHashSet("java.lang.Float", "float", "java.lang.Double", "double").contains($column.type))
 #set($jdbcType="NUMERIC")
 #elseif($tool.newHashSet("java.util.Date", "java.sql.Timestamp", "java.time.Instant", "java.time.LocalDateTime", "java.time.OffsetDateTime", "	java.time.ZonedDateTime").contains($column.type))
 #set($jdbcType="TIMESTAMP")
 #elseif($tool.newHashSet("java.sql.Date", "java.time.LocalDate").contains($column.type))
 #set($jdbcType="TIMESTAMP")
 #else
 ##    
 #set($jdbcType="OTHER")
 #end
 $tool.call($column.ext.put("jdbcType", $jdbcType))
#end

##   ,     
#macro(allSqlColumn)#foreach($column in $tableInfo.fullColumn)$column.obj.name#if($velocityHasNext), #end#end#end
ここではIDEAプラグインEasyCode MyBatisの最適な構成手順についての詳細な記事を紹介します。これまでの記事を検索したり、下記の関連記事を見たりしてください。これからもよろしくお願いします。