mybatis 程式碼生成器(IDEA, Maven)及配置詳解(部分配置你應該不知道)
在使用mybatis 過程中, 當手寫JavaBean 和XML 寫的越來越多的時候, 就越來越同意出錯。這種重複性的工作, 我們當然不希望做那麼多。
還好,mybatis 為我們提供了強大的程式碼生成--MybatisGenerator 。
通過簡單的配置, 我們就可以生成各種型別的實體類, Mapper介面, MapperXML檔案, Example物件等。 通過這些生成的檔案, 我們就可以方便的進行單表進行增刪改查的操作。
以下的工具使用的都是IDEA
1 建立程式碼生成器
1.1 建立Maven專案
1.1.1 選單上選擇新建專案
File | New | Project
1.1.2 選擇左側的Maven
由於我們只是建立一個普通的專案, 此處點選Next
即可。
1.1.3 輸入GroupId
和ArtifactId
- 在我的專案中,
GroupId 填 com.homejim.mybatis ArtifactId 填 mybatis-generator
點選Next
。
1.1.4Finish
通過以上步驟, 一個普通的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>
需要改一些內容:
- 本地資料庫驅動程式jar包的全路徑(必須要改 )。
- 資料庫的相關配置(必須要改 )
- 相關表的配置(必須要改 )
- 實體類生成存放的位置。
- MapperXML 生成檔案存放的位置。
- 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 雙擊執行
執行正確後, 生成程式碼, 得到如下的結構
2 XML 配置詳解
僅僅是上面那麼簡單的使用還不夠爽。 那麼我們就可以通過更改 generator.xml 配置檔案的方式進行生成的配置。
2.1 優先
推薦檢視官方的文件。
英文不錯的:ofollow,noindex" target="_blank">官方網站 。
中文翻譯版:翻譯版網站
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 中, 是沒有<cache> 這個標籤的。 該標籤是配置快取的。
如果我們想生成這個標籤, 那麼可以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
。
2.2.4 待續
待新增。
Github
mybatis-examples 專案中的mybatis-generator 即本文使用到的所有程式碼。