上一篇文章講解了springboot+mybatis的整合:springboot整合mybatis全過程實例
整合了mybatis后操作數據庫變得更加便捷,但是帶來了另一個問題:需要大量手工創建pojo和mapper文件,而Mybatis Generator就是用來解放我們的雙手,代替我們解決這樣的重復性的工作。
總的來說:mybatis generator工具是用來自動化生成實體類、mapper配置文件、dao層代碼的工具。
在springboot整合了mybatis的基礎上,我們一步步的引入mybatis generator工具,並在瀏覽器中實現查詢,進行演示。
1.在pom.xml中的build標簽中配置mybatis generator插件:
<!--mybatis-generator--> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.5</version> <dependencies> <dependency> <groupId> mysql</groupId> <artifactId> mysql-connector-java</artifactId> <version> 5.1.39</version> </dependency> <dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>1.3.5</version> </dependency> </dependencies> <executions> <execution> <id>Generate MyBatis Artifacts</id> <phase>package</phase> <goals> <goal>generate</goal> </goals> </execution> </executions> <configuration> <!--允許移動生成的文件 --> <verbose>true</verbose> <!-- 是否覆蓋 --> <overwrite>true</overwrite> <!-- 自動生成的配置 --> <configurationFile> src/main/resources/mybatis-generator.xml</configurationFile> </configuration> </plugin> <!--mybatis-generator-->
注意:configuration標簽中的configurationFile中配置自己的Mybatis Generator配置文件。
2.創建我們的數據庫表,這里創建一個products表

3.在上面configurationFile的位置創建相應的mybatis-generator.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> <context id="DB2Tables" targetRuntime="MyBatis3"> <commentGenerator> <!-- 是否生成注釋代時間戳--> <property name="suppressDate" value="true"/> <!-- 是否去除自動生成的注釋 true:是 : false:否 --> <property name="suppressAllComments" value="true"/> </commentGenerator> <!--數據庫鏈接地址賬號密碼--> <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://127.0.0.1:3306/test" userId="test" password="test"> </jdbcConnection> <javaTypeResolver> <!--該屬性可以控制是否強制DECIMAL和NUMERIC類型的字段轉換為Java類型的java.math.BigDecimal,默認值為false,一般不需要配置。--> <property name="forceBigDecimals" value="false"/> </javaTypeResolver> <!--生成Model類存放位置--> <javaModelGenerator targetPackage="com.example.demo.models" targetProject="src/main/java"> <!--enableSubPackages:如果true,MBG會根據catalog和schema來生成子包。如果false就會直接用targetPackage屬性。默認為false。--> <property name="enableSubPackages" value="true"/> <!--trimStrings:是否對數據庫查詢結果進行trim操作,如果設置為true就會生成類似這樣public void setUsername(String username) {this.username = username == null ? null : username.trim();}的setter方法。默認值為false。--> <property name="trimStrings" value="true"/> </javaModelGenerator> <!--生成映射xml文件存放位置--> <sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources"> <property name="enableSubPackages" value="true"/> </sqlMapGenerator> <!--生成Dao類存放位置(*Mapper.java)--> <!-- 客戶端代碼,生成易於使用的針對Model對象和XML配置文件 的代碼 type="ANNOTATEDMAPPER",生成Java Model 和基於注解的Mapper對象 type="MIXEDMAPPER",生成基於注解的Java Model 和相應的Mapper對象 type="XMLMAPPER",生成SQLMap XML文件和獨立的Mapper接口 --> <javaClientGenerator type="XMLMAPPER" targetPackage="com.example.demo.dao" targetProject="src/main/java"> <property name="enableSubPackages" value="true"/> </javaClientGenerator> <!--生成對應表及類名--> <table tableName="products" domainObjectName="Products" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"> <!--useActualColumnNames:如果設置為true,那么MBG會使用從數據庫元數據獲取的列名作為生成的實體對象的屬性。 如果為false(默認值),MGB將會嘗試將返回的名稱轉換為駝峰形式。 在這兩種情況下,可以通過 元素顯示指定,在這種情況下將會忽略這個(useActualColumnNames)屬性。--> <property name="useActualColumnNames" value="true"/> <!-- 數據庫表主鍵 --> <generatedKey column="id" sqlStatement="Mysql" identity="true" /> </table> </context> </generatorConfiguration>
上面的配置中,分別將數據庫實體文件生成到src/main/java的com.example.demo.models包中,將*Mapper.java文件生成到src/main/java的com.example.demo.dao包中,將*Mapper.xml SQL映射文件生成到src/main/resources的mapper文件夾中。
<table>標簽就是我們對應到數據庫中的表,有多少個表,就建多少個table標簽。
注意:javaClientGenerator 有三種模式(type),type="ANNOTATEDMAPPER",生成Java Model 和基於注解的Mapper對象,type="MIXEDMAPPER",生成基於注解的Java Model 和相應的Mapper對象,type="XMLMAPPER",生成SQLMap 的XML格式文件和獨立的Mapper接口,上面是配置的XMLMAPPER類型,進而將*Mapper.Java文件生成到com.example.demo.dao包中,將*Mapper.xml生成到src/main/resources的mapper文件夾中。
4.使用IntelliJ IDEA生成相應pojo和mapper文件

雙擊上圖中的mybatis-generator:generate可以看見相應文件夾下生成了文件。
如果沒有mybatise-generator的話請點擊:

接着可以看見文件目錄和文件如下:

注意:給生成的ProductMapper.java加上:
@Mapper
@Repository
注解
5.創建ProductController.java控制器演示入口
package com.example.demo.controller; import com.example.demo.dao.ProductsMapper; import com.example.demo.models.Products; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; /** * Created with IntelliJ IDEA. * User: Mason * Date: 2018/6/15 * Time: 15:45 */ @RestController public class ProductController { @Autowired ProductsMapper productsMapper; @RequestMapping(value="/ps") public String ps(){ Products products = productsMapper.selectByPrimaryKey(1); return products.toString(); } }
6.啟動程序,查看演示結果

查詢成功!
基礎知識,記錄以便查閱。
