EasyCode的官方文檔請(qǐng)參考gitee
1. EasyCode插件安裝
在IDEA的插件中查找EasyCode,點(diǎn)擊安裝。
注意:如果使用默認(rèn)配置和默認(rèn)模板,請(qǐng)?zhí)^第2、3步。
2. 配置EasyCode全局信息
在IDEA的setting中配置EasyCode,設(shè)置用戶名(對(duì)應(yīng)生成代碼的@author字段),支持自定義以模板的導(dǎo)入和導(dǎo)出,用戶可以自定義
配置Type Mapper:復(fù)制默認(rèn)分組(default),生成一份自己的分組(MyGroup),然后在自己的分組上進(jìn)行個(gè)性化修改。不建議直接修改default。
columnType對(duì)應(yīng)數(shù)據(jù)庫(kù)表的字段類型,用正則表達(dá)式,詳細(xì)的語法參考正則語法。
javaType對(duì)應(yīng)生成的Java Entity中屬性的類型。
同樣可以點(diǎn)擊+/-號(hào)添加/或刪除映射關(guān)系。
示例中數(shù)據(jù)庫(kù)的timestamp類型和java.sql.Timestamp類對(duì)應(yīng)
3. 配置EasyCode的Velocity模板
為每個(gè)Java類(Controller, ServiceImpl, Mapper, Entity)配置一個(gè)生成模板,配置使用Velocity語法。
3.1 復(fù)制一個(gè)分組(MyBatisPlusWRB),本文復(fù)制的是MyBatisPlus模板。
3.2 編輯模板,進(jìn)行個(gè)性化定制,用到的屬性和對(duì)象信息參考下方的說明文檔。
3.3 實(shí)時(shí)調(diào)試,關(guān)聯(lián)一個(gè)已經(jīng)建好的庫(kù)表,點(diǎn)擊右側(cè)>符便可預(yù)覽根據(jù)這張表生成的Java類。
4. 使用EasyCode生成Java類
選中database連接中的一張(也可以按住Ctr鍵,選擇多張表),右鍵選擇"EasyCode-Generate Code",在對(duì)話框選擇模板分組(默認(rèn)或自定義的)。
勾選要生成的Java類對(duì)應(yīng)的模板和生成路徑等信息,點(diǎn)擊OK便可生成。
來自EasyCode官網(wǎng)
5. 個(gè)人模板分享
下面分享一下我根據(jù)個(gè)人喜好配置的自定義MyBatisPlus模板
5.1 Service模塊
##導(dǎo)入宏定義
$!{define.vm}
##設(shè)置表后綴(宏定義)
#setTableSuffix("Service")
##保存文件(宏定義)
#save("/service", "Service.java")
##包路徑(宏定義)
#setPackageSuffix("service")
import com.baomidou.mybatisplus.extension.service.IService;
import $!{tableInfo.savePackageName}.entity.$!{tableInfo.name}PO;
##表注釋(宏定義)
#tableComment("表服務(wù)接口")
public interface $!{tableName} extends IService<$!{tableInfo.name}PO> {
}
5.2 ServiceImpl模板
##導(dǎo)入宏定義
$!{define.vm}
##設(shè)置表后綴(宏定義)
#setTableSuffix("ServiceImpl")
##保存文件(宏定義)
#save("/service/impl", "ServiceImpl.java")
##包路徑(宏定義)
#setPackageSuffix("service.impl")
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import $!{tableInfo.savePackageName}.service.$!{tableInfo.name}Service;
import $!{tableInfo.savePackageName}.dao.$!{tableInfo.name}Mapper;
import $!{tableInfo.savePackageName}.entity.$!{tableInfo.name}PO;
import org.springframework.stereotype.Service;
##表注釋(宏定義)
#tableComment("表服務(wù)實(shí)現(xiàn)類")
@Service
public class $!{tableName} extends ServiceImpl<$!{tableInfo.name}Mapper, $!{tableInfo.name}PO> implements $!{tableInfo.name}Service {
}
5.3 Mapper模型
##導(dǎo)入宏定義
$!{define.vm}
##設(shè)置表后綴(宏定義)
#setTableSuffix("Mapper")
##保存文件(宏定義)
#save("/dao", "Mapper.java")
##包路徑(宏定義)
#setPackageSuffix("dao")
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import $!{tableInfo.savePackageName}.entity.$!{tableInfo.name}PO;
import org.apache.ibatis.annotations.Mapper;
##表注釋(宏定義)
#tableComment("表數(shù)據(jù)庫(kù)訪問層")
@Mapper
public interface $!{tableName} extends BaseMapper<$!{tableInfo.name}PO> {
}
5.4 Entiy(Persistant Object)模板
##導(dǎo)入宏定義
$!{define.vm}
##設(shè)置表后綴(宏定義)
#setTableSuffix("PO")
##保存文件(宏定義)
#save("/entity", "PO.java")
##包路徑(宏定義)
#setPackageSuffix("entity")
##自動(dòng)導(dǎo)入包(全局變量)
$!{autoImport.vm}
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import java.io.Serializable;
import lombok.NoArgsConstructor;
import lombok.Data;
##表注釋(宏定義)
#tableComment("表實(shí)體類")
@Data
@NoArgsConstructor
@TableName("$tool.hump2Underline($tableInfo.name)")
public class $!{tableName} implements Serializable {
##以第一個(gè)primary key字段沒primary key
#foreach($column in $tableInfo.pkColumn)
#set($pkColumn = $!column.name)
#break
#end
##輸出每個(gè)字段
#foreach($column in $tableInfo.fullColumn)
#if(${column.comment})
/**
* ${column.comment}
*/
#end
#if(${column.name} == ${pkColumn})
@TableId(value = "$tool.hump2Underline($column.name)", type = IdType.AUTO)
#end
private $!{tool.getClsNameByFullName($column.type)} $!{column.name};
#end
}
6. EasyCode生成界面配置
EasyCode生成代碼界面配置





