自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

開發(fā)提速神器:mybatis-plus-generator-ui

開發(fā)
本文通過實例集成的方式來詳細講解mybatis-plus-generator-ui,從相關概念到實際集成案例,以及具體的擴展開發(fā)介紹。

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

因此,我們需要一款支持高度定制化,帶圖形UI頁面,能適配多數(shù)數(shù)據(jù)庫的基礎程序生成框架。本文就介紹這款基于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框架的各類業(yè)務代碼。提供交互式的Web UI用于生成兼容mybatis-plus框架的相關功能代碼,包括Entity、Mapper、Mapper.xml、Service、Controller等,可以自定義模板以及各類輸出參數(shù),也可通過SQL查詢語句直接生成代碼。

功能列表:

  • Table查詢: 查詢配置的關系型數(shù)據(jù)庫表的列表查詢。
  • 輸出配置: 對需要生成的相關代碼,比如Entity、Mapper、Servcie、Controller等代碼模板信息進行配置,用于在轉(zhuǎn)換時調(diào)用。
  • 項目導入: 可以導入其它項目配置好的信息給本項目使用。
  • 下載模板: 支持本項目配置的模板信息下載后共享。
  • 策略配置: 直接定義各種文件的生成策略。
  • 模板上傳: 支持從別的項目中下載模板,同上傳供本項目使用。
  • SQL輸入上傳: 支持將查詢語句直接上傳或者復制到輸入框中。
  • SQL代碼生成: 基于SQL腳本生成相應的代碼。

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

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

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函數(shù)的方式運行

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

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")
    // 數(shù)據(jù)庫schema,POSTGRE_SQL,ORACLE,DB2類型的數(shù)據(jù)庫需要指定
    // .schemaName("myBusiness")
    // 如果需要修改各類生成文件的默認命名規(guī)則,可自定義一個NameConverter實例,覆蓋相應的名稱轉(zhuǎn)換方法:
    .nameConverter(new NameConverter() {
     /**
      * 自定義Service類文件的名稱規(guī)則
      */
     public String serviceNameConvert(String tableName) {
      return this.entityNameConvert(tableName) + "Service";
     }
 
     /**
      * 自定義Controller類文件的名稱規(guī)則
      */
     public String controllerNameConvert(String tableName) {
      return this.entityNameConvert(tableName) + "Action";
     }
    }).basePackage("com.github.davidfantasy.mybatisplustools.example").port(8068).build();
 
  MybatisPlusToolsApplication.run(config);
 
 }
 
}

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

3.實例運行

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

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

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

1.Table的查詢和瀏覽

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

2.輸出配置

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

3.策略配置

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

4.SQL配置生成

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

5.代碼生成

四、自定義擴展

1.相關模板調(diào)整

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

2.代碼層級的配置

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

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

除了Service、Controller、Entity、FieldName都可以實現(xiàn)自定義的擴展。下面是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;
 
/**
 * 自定義各類名稱轉(zhuǎn)換的規(guī)則
 */
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()));
    }
 
    /**
     * 自定義表字段名到實體類屬性名的轉(zhuǎn)換規(guī)則
     *
     * @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 關聯(lián)的數(shù)據(jù)表名稱名稱
     * @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目錄下,進行相應的擴展開發(fā)。

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

yarn install
yarn run build

五、總結

本文通過實例集成的方式來詳細講解mybatis-plus-generator-ui,從相關概念到實際集成案例,以及具體的擴展開發(fā)介紹。如果在工作中有這種需要,不妨采用這種方式。

項目地址:https://github.com/davidfantasy/mybatis-plus-generator-ui

責任編輯:趙寧寧 來源: 技術老男孩
相關推薦

2025-02-27 09:45:47

2024-12-20 16:49:15

MyBatis開發(fā)代碼

2022-05-20 12:24:45

分庫分表Java依賴

2021-09-27 07:56:41

MyBatis Plu數(shù)據(jù)庫批量插入

2023-07-29 22:02:06

MyBatis數(shù)據(jù)庫配置

2022-09-29 10:06:56

SQLMySQL服務端

2021-01-05 05:36:39

設計Spring Boot填充

2013-12-18 09:12:00

UI設計

2017-06-09 14:45:14

前端深度學習

2023-06-07 08:08:37

MybatisSpringBoot

2024-09-06 08:02:52

2023-06-14 08:34:18

Mybatis死鎖框架

2023-06-07 08:00:00

MySQL批量插入

2023-10-31 08:01:48

Mybatis參數(shù)jdbcurl?

2013-02-19 16:00:50

敏捷開發(fā)產(chǎn)品提速

2016-11-23 08:10:16

Android St JRebel調(diào)試神器

2023-09-13 15:09:35

軟件開發(fā)數(shù)字化進程

2023-02-15 09:34:20

公共字段mybatis變量

2024-03-26 10:30:37

Mybatis擴展庫API

2023-03-13 07:35:44

MyBatis分庫分表
點贊
收藏

51CTO技術棧公眾號