Mybatis屬於半自動ORM,在使用這個框架中,工做量最大的就是書寫Mapping的映射文件(***Entity
,***Dao
,***Mapper.xml
),因爲手動書寫很容易出錯,咱們能夠利用Mybatis-Generator來幫咱們自動生成文件。
界面模式: https://github.com/whbing/myb...
使用mybatis-generator
生成代碼只須要兩步:java
1.pom中引入插件:mysql
<!-- above are mybatis dependencies and other...--> <build> <plugins> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.4</version> <configuration> <!--是否將生成過程輸出至控制檯--> <verbose>true</verbose> <!--是否覆蓋:否--> <overwrite>false</overwrite> </configuration> </plugin> </plugins> </build>
2.資源目錄(resources
)下放置generatorConfig.xml
文件:git
generatorConfig.xml
主要配置及說明:github
<?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> <classPathEntry location="/Users/{your_pc}/.m2/repository/mysql/mysql-connector-java/5.1.39/mysql-connector-java-5.1.39.jar" /> <context id="context1" defaultModelType="hierarchical" targetRuntime="MyBatis3Simple"> <!-- 爲了防止生成的代碼中有不少註釋,比較難看,加入下面的配置控制 --> <!-- 是否去除自動生成的註釋 true:是 :false:否 --> <commentGenerator > <property name="suppressDate" value="true"/> <property name="suppressAllComments" value="true"/> </commentGenerator> <!--去除註釋的配置要放在數據庫配置的前面,否則會報錯--> <!-- 註釋end --> <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:MySql://localhost/jms3?characterEncoding=UTF-8&allowMultiQueries=true" userId="root" password="whb" /> <javaModelGenerator targetPackage="com.***.domain.entity" targetProject="src/main/java" /> <sqlMapGenerator targetPackage="sqlmap/mysql" targetProject="src/main/resources" /> <javaClientGenerator targetPackage="com.***.dao" targetProject="src/main/java" type="XMLMAPPER" /> <table tableName="capri_task" domainObjectName="TaskEntity" enableCountByExample="true" enableUpdateByExample="true" enableDeleteByExample="true" enableSelectByExample="true" selectByExampleQueryId="false"></table> <table tableName="other..." ...some config...></table> </context> </generatorConfiguration>
使用Maven Project插件,雙擊mybatis-generator:generate
便可在對應位置下生成文件。sql
上述僅僅引入了mybatis-generator插件,其依賴的mysql jar包須要在配置中明確寫出。實際上,還能夠經過同時引入mybatis-generator依賴和插件,來優化上述配置。 詳情
詳情數據庫
<generatorConfiguration> (1) <!-- 能夠用於加載或者配置文件,使用${propertyKey} resource:從classpath開始找,好比*/generatorConfig.properties url:使用URL的絕對路徑方式 注意 兩個屬性只能選址一個; 另外,若是使用了mybatis-generator-maven-plugin,那麼在pom.xml中定義的properties均可以直接在generatorConfig.xml中使用 --> <properties resource="" url="" /> (2) <!-- 額外依賴包 如mysql鏈接包--> <classPathEntry location="..."/> (3) <!-- context:生成一組對象的環境 id:必選,上下文id,用於在生成錯誤時提示 defaultModelType:指定生成對象的樣式 1,conditional:相似hierarchical; 2,flat:全部內容(主鍵,blob)等所有生成在一個對象中; 3,hierarchical:主鍵生成一個XXKey對象(key class),Blob等單獨生成一個對象,其餘簡單屬性在一個對象中(record class) targetRuntime: 1,MyBatis3:默認的值,生成基於MyBatis3.x以上版本的內容,包括XXXBySample; 2,MyBatis3Simple:相似MyBatis3,只是不生成XXXBySample;--> <context id="context1" defaultModelType="flat"> ...
運行mybatis-generator
插件,便可自動生成,即在指定的文件夾下,生成:mybatis
*Mapper.java, *Mapper.xml, Entity