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ù)庫表的字段類型,用正則表達(dá)式驻谆,詳細(xì)的語法參考正則語法。
javaType對(duì)應(yīng)生成的Java Entity中屬性的類型勺卢。
同樣可以點(diǎn)擊+/-號(hào)添加/或刪除映射關(guān)系黑忱。
示例中數(shù)據(jù)庫的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)建好的庫表方庭,點(diǎn)擊右側(cè)>符便可預(yù)覽根據(jù)這張表生成的Java類厕吉。
4. 使用EasyCode生成Java類
選中database連接中的一張(也可以按住Ctr鍵,選擇多張表)械念,右鍵選擇"EasyCode-Generate Code"头朱,在對(duì)話框選擇模板分組(默認(rèn)或自定義的)。
勾選要生成的Java類對(duì)應(yīng)的模板和生成路徑等信息龄减,點(diǎn)擊OK便可生成项钮。
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ù)庫訪問層")
@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
}