你還在手寫 CRUD?試試 MybatisGenerator,不再用加班了!

在使用 mybatis 過程當中, 當手寫 JavaBeanXML 寫的愈來愈多的時候, 就愈來愈贊成出錯。這種重複性的工做, 咱們固然不但願作那麼多。java

還好, mybatis 爲咱們提供了強大的代碼生成--MybatisGeneratormysql

經過簡單的配置, 咱們就能夠生成各類類型的實體類, Mapper接口, MapperXML文件, Example對象等。 經過這些生成的文件, 咱們就能夠方便的進行單表進行增刪改查的操做。面試

如下的工具使用的都是 IDEAspring

一、建立代碼生成器

1.1 建立Maven項目

1.1.1 菜單上選擇新建項目sql

File | New | Project數據庫

1.1.2 選擇左側的Mavenapache

因爲咱們只是建立一個普通的項目, 此處點擊 Next便可。api

1.1.3 輸入GroupIdArtifactId緩存

在個人項目中,mybatis

GroupId 填 com.homejim.mybatis

ArtifactId 填 mybatis-generator

點擊 Next

1.1.4 Finish

經過以上步驟, 一個普通的Maven項目就建立好了。

1.2 配置 generator.xml

其實名字無所謂, 只要跟下面的 pom.xml 文件中的對應上就行了。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE generatorConfiguration PUBLIC
        "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd" >
<generatorConfiguration>

    <!-- 本地數據庫驅動程序jar包的全路徑 -->
    <classPathEntry location="C:\Users\\Administrator\\.m2\repository\\mysql\\mysql-connector-java\\8.0.12\\mysql-connector-java-8.0.12.jar"/>
    <context id="context" targetRuntime="MyBatis3">
        <commentGenerator>
            <property name="suppressAllComments" value="false"/>
            <property name="suppressDate" value="true"/>
        </commentGenerator>

        <!-- 數據庫的相關配置 -->
        <jdbcConnection
                driverClass="com.mysql.jdbc.Driver"
                connectionURL="jdbc:mysql://localhost:3306/mybatis"
                userId="root"
                password="jim777"/>

        <javaTypeResolver>
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>

        <!-- 實體類生成的位置 -->
        <javaModelGenerator
                targetPackage="com.homejim.mybatis.entity"
                targetProject=".\src\main\java">
            <property name="enableSubPackages" value="false"/>
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>

        <!-- *Mapper.xml 文件的位置  sqlMapGenerator-->
        <sqlMapGenerator
                targetPackage="mybatis/mapper"
                targetProject=".\src\main\resources">
            <property name="enableSubPackages" value="false"/>
        </sqlMapGenerator>

        <!-- Mapper 接口文件的位置 -->
        <javaClientGenerator type="XMLMAPPER"
                             targetPackage="com.homejim.mybatis.mapper"
                             targetProject=".\src\main\java">
            <property name="enableSubPackages" value="false"/>
        </javaClientGenerator>

        <!-- 相關表的配置 -->

        <table tableName="blog" />
    </context>
</generatorConfiguration>

須要改一些內容:

  1. 本地數據庫驅動程序jar包的全路徑(必需要改)。
  2. 數據庫的相關配置(必需要改
  3. 相關表的配置(必需要改
  4. 實體類生成存放的位置。
  5. MapperXML 生成文件存放的位置。
  6. Mapper 接口存放的位置。

若是不知道怎麼改, 請看後面的配置詳解

1.3 配置 pom.xml

在原基礎上添加一些內容。

<?xml version="1.0" encoding="UTF-8"?>
<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.homejim.mybatis</groupId>
    <artifactId>mybatis-generator</artifactId>
    <version>1.0-SNAPSHOT</version>
    <!--在原基礎上添加 這些就行了-->
    <build>
        <finalName>mybatis-generator</finalName>
        <plugins>
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.7</version>
                <configuration>
                   <!--此處須要注意, 文件與上面的文件匹配-->
                   <configurationFile>src/main/resources/generator.xml</configurationFile>
                    <verbose>true</verbose>
                    <overwrite>true</overwrite>
                </configuration>
                <executions>
                    <execution>
                        <id>Generate MyBatis Artifacts</id>
                        <goals>
                            <goal>generate</goal>
                        </goals>
                    </execution>
                </executions>
                <dependencies>
                    <dependency>
                        <groupId>org.mybatis.generator</groupId>
                        <artifactId>mybatis-generator-core</artifactId>
                        <version>1.3.7</version>
                    </dependency>
                </dependencies>
            </plugin>
        </plugins>
    </build>
    <!--到此結束-->
</project>

須要注意的是 configurationFile 中的文件指的是 generator.xml。 所以路徑寫的是該文件的相對路徑, 名稱也跟該文件相同。

到此, mybatis-generator 就可使用啦。

1.4 使用及測試

1.4.1 打開 Maven Projects 視圖

在 IDEA 上, 打開:

View | Tools | Windwos | Maven Projects

1.4.2 Maven Projects 中雙擊 mybatis-generator

在右側此時能夠看到 Maven Projects 了。找到 mybatis-generator 插件。

mybatis-generator | Plugins | mybatis-generator | mybatis-generator

1.4.3 雙擊運行

運行正確後, 生成代碼, 獲得以下的結構:

二、XML 配置詳解

僅僅是上面那麼簡單的使用還不夠爽。 那麼咱們就能夠經過更改 generator.xml 配置文件的方式進行生成的配置。

2.1 優先

推薦查看官方的文檔。

2.2 官網沒有的

2.2.1 property 標籤

該標籤在官網中只是說用來指定元素的屬性, 至於怎麼用沒有詳細的講解。

2.2.1.1 分隔符相關

<property name="autoDelimitKeywords" value="true"/>
<property name="beginningDelimiter" value="`"/>
<property name="endingDelimiter" value="`"/>

以上的配置對應的是 mysql當數據庫中的字段和數據庫的關鍵字同樣時, 就會使用分隔符。

好比咱們的數據列是 delete, 按以上的配置後, 在它出現的地方, 就變成 delete

2.2.1.2 編碼

默認是使用當前的系統環境的編碼, 能夠配置爲 GBK 或 UTF-8。

<property name="javaFileEncoding" value="UTF-8"/>

我想項目爲 UTF-8, 若是指定生成 GBK, 則自動生成的中文就是亂碼。

2.2.1.3 格式化

<!--格式化生成的 Java 代碼-->
<property name="javaFormatter" value="org.mybatis.generator.api.dom.DefaultJavaFormatter"/>
<!--格式化生成的 XML-->
<property name="xmlFormatter" value="org.mybatis.generator.api.dom.DefaultXmlFormatter"/>

這些顯然都是能夠自定義實現的的。

2.2.2 plugins 標籤

plugins 標籤用來擴展或修改代碼生成器生成的代碼。

在生成的 XML 中, 是沒有 這個標籤的。 該標籤是配置緩存的。

若是咱們想生成這個標籤, 那麼能夠 plugins 中進行配置。

<plugin type="org.mybatis.generator.plugins.CachePlugin" >
    <property name="cache_eviction" value="LRU"/>
</plugin>

好比你想生成的 JavaBean 中自行實現 Serializable 接口。

<plugin type="org.mybatis.generator.plugins.SerializablePlugin" />

還能自定義插件。

這些插件都蠻有用的, 感受後續能夠專門開一篇文章來說解。

2.2.3 commentGenerator 標籤

看名稱, 就知道是用來生成註釋用的。

默認配置:

<commentGenerator >
    <property name="suppressAllComments" value="false"/>
    <property name="suppressDate" value="false"/>
    <property name="addRemarkComments" value="false"/>
</commentGenerator>

suppressAllComments: 阻止生成註釋, 默認值是false。

suppressDate: 阻止生成的註釋包含時間戳, 默認爲false。

addRemarkComments: 註釋中添加數據庫的註釋, 默認爲 false。

還有一個就是咱們能夠經過 type 屬性指定咱們自定義的註解實現類, 生成咱們本身想要的註解。 自定義的實現類須要實現 org.mybatis.generator.api.CommentGenerator

最後,關注公衆號Java技術棧,在後臺回覆:面試,能夠獲取我整理的 Java 系列面試題和答案,很是齊全。

做者:阿進的寫字檯
出處:https://www.cnblogs.com/homejim/
本文版權歸做者和博客園共有,歡迎轉載,但未經做者贊成必須保留此段聲明,且在文章頁面明顯位置給出原文鏈接,不然保留追究法律責任的權利。
近期熱文推薦:

1.Java 15 正式發佈, 14 個新特性,刷新你的認知!!

2.終於靠開源項目弄到 IntelliJ IDEA 激活碼了,真香!

3.我用 Java 8 寫了一段邏輯,同事直呼看不懂,你試試看。。

4.吊打 Tomcat ,Undertow 性能很炸!!

5.《Java開發手冊(嵩山版)》最新發布,速速下載!

以爲不錯,別忘了隨手點贊+轉發哦!

相關文章
相關標籤/搜索