使用mybatis-generator工具加快開發速度

    在使用mybatis時,需要書寫大量的mapping映射文件,手動書寫工作量大並且容易出錯。值得慶幸的是,Mybatis-Generator可以用來幫助我們自動生成這些文件,大幅度提高開發效率。

    1.準備工作

從https://github.com/mybatis/generator/releases下載mybatis-generator的jar包;

從http://www.grepcode.com下載數據庫驅動包。

新建如下結構目錄:

wKiom1c5ZvSyZcv4AACJu0KIDoM213.png

2.generator.xml介紹

生成相關文件前,需要進行配置,配置文件名稱任意,後綴爲xml。(屬性相關解釋在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>
    <!--數據庫驅動-->
    <classPathEntry  location="mysql-connector-java-5.1.36.jar"/>
    <context id="DB2Tables" targetRuntime="MyBatis3">
        <commentGenerator>
            <property name="suppressDate" value="true"/>
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>
        <!--數據庫鏈接地址賬號密碼-->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost/mybatis" userId="root" password="yxc.">
        <!--oracle數據庫
        <jdbcConnection driverClass="oracle.jdbc.driver.OracleDriver"  
          connectionURL="jdbc:oracle:thin:@localhost:1521:ORCL"  
          userId="username"  
          password="password">  
        </jdbcConnection>  
        -->
        </jdbcConnection>
        <!--  默認false,把JDBC DECIMAL 和 NUMERIC 類型解析爲 Integer;
         true,把JDBC DECIMAL 和 NUMERIC 類型解析爲java.math.BigDecimal   
        -->   
        <javaTypeResolver>
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>
        <!--生成Model類存放位置-->
        <javaModelGenerator targetPackage="yb.model" targetProject="src">
            <!-- enableSubPackages:是否讓schema作爲包的後綴 -->
            <property name="enableSubPackages" value="true"/>
            <!-- 從數據庫返回的值被清理前後的空格  -->
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>
        <!--生成映射文件存放位置-->
        <sqlMapGenerator targetPackage="yb.mapping" targetProject="src">
            <property name="enableSubPackages" value="true"/>
        </sqlMapGenerator>
        <!--生成Dao類存放位置-->
        <javaClientGenerator type="XMLMAPPER" targetPackage="yb.dao" targetProject="src">
            <property name="enableSubPackages" value="true"/>
        </javaClientGenerator>
        <!--生成對應表及類名-->
        <!-- tableName:用於自動生成代碼的數據庫表;domainObjectName:對應於數據庫表的javaBean類名
        若要生成例子可將enableCountByExample等設爲true, 就會生成一個對應domainObjectName的Example類,false則不生成,默認策略是true。
        類似的還有enableUpdateByExample、enableDeleteByExample、enableSelectByExample、selectByExampleQueryId屬性。
        -->  
        <table tableName="phone" domainObjectName="Phone" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
    </context>
</generatorConfiguration>

3.運行

運行有四種:命令生成(最簡單)、Java生成、ant生成、maven生成。這裏說前面兩種,有興趣其餘的可以在mybatis官網去學習。

1)打開cmd命令窗口,cd到工作目錄中,運行如下命令

java - jar mybatis-generator包的文件路徑  -configfile  generator.xml的文件路徑  -overwrite 命令。

本例爲:

java -jar mybatis-generator-core-1.3.2.jar -configfile generator.xml -overwrite

成功時輸出:MyBatis Generator finished successfully.

2)java生成

 List<String> warnings = new ArrayList<String>();
   boolean overwrite = true;
   File configFile = new File("generatorConfig.xml");
   ConfigurationParser cp = new ConfigurationParser(warnings);
   Configuration config = cp.parseConfiguration(configFile);
   DefaultShellCallback callback = new DefaultShellCallback(overwrite);
   MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);

   myBatisGenerator.generate(null);

其實Java運行,細分可以分兩種,還有一種可以去官網學習。

4.效果

wKioL1c5a7vi79A2AACVIFv3us0207.png

wKioL1c5bQbwvtmwAAA-fHwN4yU910.png

wKioL1c5bQejpsVPAADUqRr-h6o142.png

wKioL1c5bQeT31-PAABZHp5ls8U801.png

生成代碼之後,根據自己的實際項目架構,可以對生成的代碼進行適當的修改,如把數據庫管理交有spring等等。

5.注意點

1)generator.xml格式:必須是以UTF-8無BOM格式編碼,用notepad++轉換。
2)注意數據庫包的可用性,無效的數據庫包轉換會報錯。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章