試試MyBatis-Plus可視化代碼生成器,太香了,你一定會感謝我

前言

在基于Mybatis的開發模式中,很多開發者還會選擇Mybatis-Plus來輔助功能開發,以此提高開發的效率。雖然Mybatis也有代碼生成的工具,但Mybatis-Plus由于在Mybatis基礎上做了一些調整,因此,常規的生成工具生成的代碼還有一些不太符合預期。而且對于多數據庫的支持不是很好。

因此,我們需要一款支持高度定制化,帶圖形UI頁面,能適配多數數據庫的基礎程序生成框架。本文就介紹這款基于Mybatis-Plus的代碼自助生成器,github地址:mybatis-plus-generator-ui。

文章通過實例集成的方式來詳細講解mybatis-plus-generator-ui,感興趣的朋友可以自己clone下來,也可以自己進行擴展自定義。

一、mybatis-plus-generator-ui是什么?

它是對mybatis-plus-generator進行封裝,通過Web UI快速生成兼容Spring boot,mybatis-plus框架的各類業務代碼。提供交互式的Web UI用于生成兼容mybatis-plus框架的相關功能代碼,包括Entity、Mapper、Mapper.xml、Service、Controller等,可以自定義模板以及各類輸出參數,也可通過SQL查詢語句直接生成代碼。

圖片

圖片

功能列表:

  • Table查詢:?查詢配置的關系型數據庫表的列表查詢。

  • 輸出配置:?對需要生成的相關代碼,比如Entity、Mapper、Servcie、Controller等代碼模板信息進行配置,用于在轉換時調用。

  • 項目導入:?可以導入其它項目配置好的信息給本項目使用。

  • 下載模板:?支持本項目配置的模板信息下載后共享。

  • 策略配置:?直接定義各種文件的生成策略。

  • 模板上傳:?支持從別的項目中下載模板,同上傳供本項目使用。

  • SQL輸入上傳:?支持將查詢語句直接上傳或者復制到輸入框中。

  • SQL代碼生成:?基于SQL腳本生成相應的代碼。

二、 mybatis-plus-generator-ui怎么用?

mybatis-plus-generator-ui提供以jar包的形式為外部項目提供服務,通過配置的數據庫配置去讀取數據庫的配置信息,并通過Web UI的方式提供給開發者使用。mybatis-plus-generator-ui支持POSTGRE_SQL、ORACLE、DB2、MySQL、SQLSERVER等常見的關系型數據庫。

推薦一個開源免費的 Spring Boot 最全教程:

https://github.com/javastacks/spring-boot-best-practice

1、maven pom引入

<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.yelang</groupId> ?<artifactId>mybatis-plus-generator-ui-case</artifactId> ?<version>0.0.1-SNAPSHOT</version> ?<dependencies> ??<dependency> ???<groupId>com.github.davidfantasy</groupId> ???<artifactId>mybatis-plus-generator-ui</artifactId> ???<version>1.4.5</version> ??</dependency> ??<dependency> ???<groupId>org.postgresql</groupId> ???<artifactId>postgresql</artifactId> ???<version>42.2.25</version> ??</dependency> ?</dependencies> </project>?

2、新建程序入口,以main函數的方式運行

mybatis-plus-generator-ui在1.4.0版本之后,可支持將GeberatorUIServer獨立部署為一個單獨的spring boot項目,通過頁面指定目標項目根目錄的方式為多個項目提供源碼生成服務。這種方式適用于有多個項目庫需要獨立進行開發的模式。實例關鍵代碼如下:

package?com.yelang; import?com.github.davidfantasy.mybatisplus.generatorui.GeneratorConfig; import?com.github.davidfantasy.mybatisplus.generatorui.MybatisPlusToolsApplication; import?com.github.davidfantasy.mybatisplus.generatorui.mbp.NameConverter; public?class?GeneratorMain?{ ?public?static?void?main(String[]?args)?{ ??GeneratorConfig?config?=?GeneratorConfig.builder().jdbcUrl("jdbc:postgresql://127.0.0.1:5432/ghyapp") ????.userName("ghy01").password("ghy01").driverClassName("org.postgresql.Driver") ????//?數據庫schema,POSTGRE_SQL,ORACLE,DB2類型的數據庫需要指定 ????//?.schemaName("myBusiness") ????//?如果需要修改各類生成文件的默認命名規則,可自定義一個NameConverter實例,覆蓋相應的名稱轉換方法: ????.nameConverter(new?NameConverter()?{ ?????/** ??????*?自定義Service類文件的名稱規則 ??????*/ ?????public?String?serviceNameConvert(String?tableName)?{ ??????return?this.entityNameConvert(tableName)?+?"Service"; ?????} ?????/** ??????*?自定義Controller類文件的名稱規則 ??????*/ ?????public?String?controllerNameConvert(String?tableName)?{ ??????return?this.entityNameConvert(tableName)?+?"Action"; ?????} ????}).basePackage("com.github.davidfantasy.mybatisplustools.example").port(8068).build(); ??MybatisPlusToolsApplication.run(config); ?} }?

在上面的配置中,我們連接的示例數據庫是PostgerSQL,需要在Maven中定義相應的驅動程序,并且在上述代碼中正確配置相應的類。最后指定了程序的運行端口為8086,這種運行方式跟SpringBoot非常相似。

另外,如果你近期準備面試跳槽,建議在Java面試庫小程序在線刷題,涵蓋 2000+?道 Java 面試題,幾乎覆蓋了所有主流技術面試題。

3、實例運行

運行以上的main方法,在控制臺可以看到以下輸出即為成功部署。

圖片

在輸出的日志中,可以看到程序的運行端口,以及默認的模板目錄地址。在瀏覽器中輸入訪問地址http://localhost:8068/,即可進行配置生成。

三、mybatis-plus-generator-ui代碼生成

1、Table的查詢和瀏覽

可以直接瀏覽和查詢配置的數據源的數據表信息,可選擇一個或多個生成模板代碼。

圖片

2、輸出配置

內置Entity、Mapper、Service、Controller等6種類型代碼的模板配置,可以上傳模板進行替換,并修改各類參數,配置參數已經按照影響的文件類型重新進行了分類,并加入了部分文本說明;也可以自行添加其它類型的自定義輸出文件。所有的配置項都會按照項目包名進行保存,只需一次性設置就可以了。

圖片

3、策略配置

將每次生成代碼時可能變動的內容加入到代碼生成選項中,方便調整每次的生成策略,比如:是否覆蓋原文件,生成文件的種類等等:

圖片

4、SQL配置生成

通過輸入查詢SQL,可自動在Mapper(Xml及Java)中生成對應的查詢方法,DTO對象和ResultMap(結果集映射配置)

圖片

5、代碼生成

圖片

圖片

四、自定義擴展

1、相關模板調整

在相關的頁面中,可以進行相應的調整,在對應的btl模板中下載對應文件的具體模板,使用文本工具打開,直接修改源代碼,文中取一種方式示例,其它方式一樣。

圖片

圖片

2、代碼層級的配置

在一些團隊中,肯定對Mapper的定義為Dao,Controller層需要定義為Action,通過修改代碼模板btl的方式是可以的,還有一種方式是通過調整內部映射的方式來進行修改。主要使用的類是NameConverter。

/**
*?自定義Service類文件的名稱規則
*/
public?String?serviceNameConvert(String?tableName)?{return?this.entityNameConvert(tableName)?+?"Service";
}/**
*?自定義Controller類文件的名稱規則
*/
public?String?controllerNameConvert(String?tableName)?{return?this.entityNameConvert(tableName)?+?"Action";
}

除了Service、Controller、Entity、FieldName都可以實現自定義的擴展。下面是NameConverter類的核心代碼,這里有詳細的定義。

package?com.github.davidfantasy.mybatisplus.generatorui.mbp;import?cn.hutool.core.util.StrUtil;
import?com.github.davidfantasy.mybatisplus.generatorui.dto.Constant;
import?com.google.common.base.Strings;import?static?com.github.davidfantasy.mybatisplus.generatorui.dto.Constant.DOT_JAVA;
import?static?com.github.davidfantasy.mybatisplus.generatorui.dto.Constant.DOT_XML;/***?自定義各類名稱轉換的規則*/
public?interface?NameConverter?{/***?自定義Entity.java的類名稱**?@param?tableName?表名稱*?@return*/default?String?entityNameConvert(String?tableName)?{if?(Strings.isNullOrEmpty(tableName))?{return?"";}tableName?=?tableName.substring(tableName.indexOf(StrUtil.UNDERLINE)?+?1,?tableName.length());return?StrUtil.upperFirst(StrUtil.toCamelCase(tableName.toLowerCase()));}/***?自定義表字段名到實體類屬性名的轉換規則**?@param?fieldName?表字段名稱*?@return*/default?String?propertyNameConvert(String?fieldName)?{if?(Strings.isNullOrEmpty(fieldName))?{return?"";}if?(fieldName.contains("_"))?{return?StrUtil.toCamelCase(fieldName.toLowerCase());}return?fieldName;}/***?自定義Mapper.java的類名稱*/default?String?mapperNameConvert(String?tableName)?{return?entityNameConvert(tableName)?+?"Mapper";}/***?自定義Mapper.xml的文件名稱*/default?String?mapperXmlNameConvert(String?tableName)?{return?entityNameConvert(tableName)?+?"Mapper";}/***?自定義Service.java的類名稱*/default?String?serviceNameConvert(String?tableName)?{return?"I"?+?entityNameConvert(tableName)?+?"Service";}/***?自定義ServiceImpl.java的類名稱*/default?String?serviceImplNameConvert(String?tableName)?{return?entityNameConvert(tableName)?+?"ServiceImpl";}/***?自定義Controller.java的類名稱*/default?String?controllerNameConvert(String?tableName)?{return?entityNameConvert(tableName)?+?"Controller";}/***?自定義其它生成文件的文件名(不包括entity,mapper.java,mapper.xml,service,serviceImpl,controller這6種)**?@param?fileType??在頁面上輸入的輸出文件標識*?@param?tableName?關聯的數據表名稱名稱*?@return?生成文件的名稱,帶后綴*/default?String?outputFileNameConvert(String?fileType,?String?tableName)?{if?(fileType.equals(Constant.FILE_TYPE_ENTITY))?{return?this.entityNameConvert(tableName)?+?DOT_JAVA;}?else?if?(fileType.equals(Constant.FILE_TYPE_MAPPER))?{return?this.mapperNameConvert(tableName)?+?DOT_JAVA;}?else?if?(fileType.equals(Constant.FILE_TYPE_MAPPER_XML))?{return?this.mapperXmlNameConvert(tableName)?+?DOT_XML;}?else?if?(fileType.equals(Constant.FILE_TYPE_SERVICE))?{return?this.serviceNameConvert(tableName)?+?DOT_JAVA;}?else?if?(fileType.equals(Constant.FILE_TYPE_SERVICEIMPL))?{return?this.serviceImplNameConvert(tableName)?+?DOT_JAVA;}?else?if?(fileType.equals(Constant.FILE_TYPE_CONTROLLER))?{return?this.controllerNameConvert(tableName)?+?DOT_JAVA;}return?this.entityNameConvert(tableName)?+?fileType;}}

mybatis-plus-generator-ui的功能非常豐富,甚至針對ui都是可以自定義修改的。如果需要定制UI的話,將代碼clone下來后,進入到frontend目錄下,進行相應的擴展開發。

圖片

修改完成后,需要另行編譯src\frontend中的靜態資源(源碼中不包含已編譯的頁面),在src\frontend文件夾中執行:

yarn?install
yarn?run?build

五、總結

以上就是今天要講的內容,本文簡要介紹一款基于Mybatis-Plus的代碼自助生成器,地址:

https://github.com/davidfantasy/mybatis-plus-generator-ui

文章通過實例集成的方式來詳細講解mybatis-plus-generator-ui,從相關概念到實際集成案例,以及具體的擴展開發介紹。如果在工作中有這種需要,不妨采用這種方式。希望本文對您有所幫助,歡迎指導交流。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/160931.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/160931.shtml
英文地址,請注明出處:http://en.pswp.cn/news/160931.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

PC端使子組件的彈框關閉

子組件 <template><el-dialog title"新增部門" :visible"showDialog" close"close"> </el-dialog> </template> <script> export default {props: {showDialog: {type: Boolean,default: false,},},data() {retu…

【JavaSE】-5-嵌套循環

回顧 一、java語言特點 二、配置java環境 path 三、記事本 javac -d . java 包名.類名 四、eclipse 五、變量 定義變量 數據類型 變量名值; 六、相關的數據類型 ? 基本&#xff08;四類 、8種&#xff09;、引用 ? 類型轉換&#xff08;自動、強制&#xff09; ? 運…

Java面向對象(高級)-- 類中屬性賦值的位置及過程

文章目錄 一、賦值順序&#xff08;1&#xff09;賦值的位置及順序&#xff08;2&#xff09;舉例&#xff08;3&#xff09;字節碼文件&#xff08;4&#xff09;進一步探索&#xff08;5&#xff09;最終賦值順序&#xff08;6&#xff09;實際開發如何選 二、(超綱)關于字節…

1992-2021年省市縣經過矯正的夜間燈光數據(GNLD、VIIRS)

1992-2021年省市縣經過矯正的夜間燈光數據&#xff08;GNLD、VIIRS&#xff09; 1、時間&#xff1a;1992-2021年3月&#xff0c;其中1992-2013年為年度數據&#xff0c;2013-2021年3月為月度數據 2、來源&#xff1a;DMSP、VIIRS 3、范圍&#xff1a;分區域匯總&#xff1a…

SpringBoot : ch05 整合Mybatis

前言 隨著Java Web應用程序的快速發展&#xff0c;開發人員需要越來越多地關注如何高效地構建可靠的應用程序。Spring Boot作為一種快速開發框架&#xff0c;旨在簡化基于Spring的應用程序的初始搭建和開發過程。而MyBatis作為一種優秀的持久層框架&#xff0c;提供了對數據庫…

【Linux】-進程間通信-共享內存(SystemV),詳解接口函數以及原理(使用管道處理同步互斥機制)

&#x1f496;作者&#xff1a;小樹苗渴望變成參天大樹&#x1f388; &#x1f389;作者宣言&#xff1a;認真寫好每一篇博客&#x1f4a4; &#x1f38a;作者gitee:gitee? &#x1f49e;作者專欄&#xff1a;C語言,數據結構初階,Linux,C 動態規劃算法&#x1f384; 如 果 你 …

中低壓MOSFET 2N7002T 60V 300mA 雙N通道 采用SOT-523封裝形式

2N7002KW小電流雙N通道MOSFET&#xff0c;電壓60V電流300mA&#xff0c;采用SOT-523封裝形式。低Ros (on)的高密度單元設計&#xff0c;堅固可靠&#xff0c;具有高飽和電流能力&#xff0c;ESD防護門HBM2KV。可應用于直流/直流轉換器&#xff0c;電池開關等產品應用上。

Redis JDBC

1、導入依賴&#xff1a; <dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>4.4.3</version></dependency> 2、連接JDBC public class JedisDemo05 {public static void main(String[]…

成為AI產品經理——AI產品經理工作全流程

一、業務背景 背景&#xff1a;日常排球訓練&#xff0c;中考排球項目和排球體測項目耗費大量人力成本和時間成本。 目標&#xff1a;開發一套用于實時檢測排球運動并進行排球墊球計數和姿勢分析的軟件。 二、產品工作流程 我們這里對于產品工作流程的關鍵部分進行講解&…

「Docker」如何在蘋果電腦上構建簡單的Go云原生程序「MacOS」

介紹 使用Docker開發Golang云原生應用程序&#xff0c;使用Golang服務和Redis服務 注&#xff1a;寫得很詳細 為方便我的朋友可以看懂 環境部署 確保已經安裝Go、docker等基礎配置 官網下載鏈接直達&#xff1a;Docker官網下載 Go官網下載 操作步驟 第一步 創建一個…

Java 多線程之 DCL(Double-Checked Locking)

文章目錄 一、概述二、使用方法 一、概述 DCL&#xff08;Double-Checked Locking&#xff09;是一種用于在多線程環境下實現延遲初始化的技術。它結合了懶加載&#xff08;Lazy Initialization&#xff09;和線程安全性&#xff0c;用于在需要時創建單例對象或共享資源。它的…

什么是SEO?(初學者建議收藏)

前言 在這個充滿機遇和挑戰的時代&#xff0c;人們不斷追求著更好的生活和更高的成就。無論是個人還是企業&#xff0c;都需要不斷提升自己的競爭力&#xff0c;才能在激烈的市場競爭中獲得成功。因此&#xff0c;我們需要不斷學習和成長&#xff0c;學會適應變化和面對挑戰。…

汽車智能座艙/智能駕駛SOC -2

第二篇&#xff08;筆記&#xff09;。 未來智能汽車電子電氣將會是集中式架構&#xff08;車載數據中心&#xff09;虛擬化技術&#xff08;提供車載數據中心靈活性和安全性&#xff09;這個幾乎是毋庸置疑的了。國際大廠也否紛紛布局超算芯片和車載數據中心平臺。但是演進需…

日期格式轉化成星期幾部署到linux顯示英文

異常收集 原因&#xff1a;解決辦法仰天大笑出門去&#xff0c;我輩豈是蓬蒿人 傳入一個時間獲取這個時間對應的是星期幾&#xff0c;在開發環境&#xff08;window系統&#xff09;中顯示為星期幾&#xff0c;部署到服務器&#xff08;linux系統&#xff09;中會顯示英文的時間…

serverless開發實戰

.yml格式 YAML&#xff08;YAML Ain’t Markup Language&#xff09;是一種人類可讀的數據序列化格式&#xff0c;它使用簡潔的結構和縮進來表示數據。它被廣泛用于配置文件和數據交換的場景&#xff0c;具有易讀性和易寫性的特點。 serverless.yml配置 在項目的根目錄下增加…

Youtube新手運營——你需要的技巧與工具

對于有跨境意向的內容創作者或者品牌企業來說&#xff0c;YouTube是因其巨大的潛在受眾群和商業價值成為最值得投入變現與營銷計劃的平臺。 據統計&#xff0c;98% 的美國人每月訪問 YouTube&#xff0c;近三分之二的人每天訪問。但是&#xff0c;YouTube還遠未達到過度飽和的…

Leetcode—53.最大子數組和【中等】

2023每日刷題&#xff08;三十四&#xff09; Leetcode—53.最大子數組和 前綴和算法思想 參考靈茶山艾府 實現代碼 #define MAX(a, b) ((a > b) ? (a) : (b)) #define MIN(a, b) ((a < b) ? (a) : (b)) int maxSubArray(int* nums, int numsSize) {int ans INT_…

VMware 16 Pro 安裝以及下載

1、下載地址&#xff1a; https://www.aliyundrive.com/s/nj3PSD4TN9G 2、安裝文件 右擊打開 下一步 密鑰&#xff1a;ZF3R0-FHED2-M80TY-8QYGC-NPKYF 到此&#xff0c;安裝完畢

postgreSQL如何快速查詢大表數據量

文章目錄 場景方案結果 場景 我有一個非常大的表&#xff0c;估計幾百萬或者幾千萬。 我開始使用了 select count(*) from my_table_javapub 方式&#xff0c;查詢非常慢。 如何解決&#xff1f;&#xff1f;&#xff1f; 方案 如果你需要更快地獲取表中的行數&#xff0c…