mybatis入門基礎(九)----逆向工程

阿赫瓦里發表於2015-07-16

一、什麼是逆向工程  

      mybaits需要程式設計師自己編寫sql語句,mybatis官方提供逆向工程 可以針對單表自動生成mybatis執行所需要的程式碼(mapper.java,mapper.xmlpo..

      實際開發中,常用的逆向工程方式:由資料庫的表生成java程式碼。

二、下載逆向工程

  去官網下載逆向工程,截至今天最新版本是1.3.3.    官方逆向工程文件

     我所用的是1.3.2版本的,下載地址: mybatis_generator所用jar包.zip

                                                 mybatis學習資料(中英文文件,引數常見配置等).rar

三、使用方法

1.生成程式碼配置檔案

 generatorConfig.xml的配置

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE generatorConfiguration
 3   PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
 4   "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
 5 
 6 <generatorConfiguration>
 7     <context id="testTables" targetRuntime="MyBatis3">
 8         <commentGenerator>
 9             <!-- 是否去除自動生成的註釋 true:是 : false:否 -->
10             <property name="suppressAllComments" value="true" />
11         </commentGenerator>
12         <!--資料庫連線的資訊:驅動類、連線地址、使用者名稱、密碼,這裡配置的是mysql的,當然也可以配置oracle等資料庫 -->
13         <jdbcConnection driverClass="com.mysql.jdbc.Driver"
14             connectionURL="jdbc:mysql://localhost:3306/mybatis" userId="root"
15             password="root">
16         </jdbcConnection>
17 
18         <!-- 預設false,把JDBC DECIMAL 和 NUMERIC 型別解析為 Integer,為 true時把JDBC DECIMAL 
19             和 NUMERIC 型別解析為java.math.BigDecimal -->
20         <javaTypeResolver>
21             <property name="forceBigDecimals" value="false" />
22         </javaTypeResolver>
23 
24         <!-- targetProject:生成PO類的位置 -->
25         <javaModelGenerator targetPackage="com.mybatis.entity"
26             targetProject=".\src">
27             <!-- enableSubPackages:是否讓schema作為包的字尾 -->
28             <property name="enableSubPackages" value="false" />
29             <!-- 從資料庫返回的值被清理前後的空格 -->
30             <property name="trimStrings" value="true" />
31         </javaModelGenerator>
32         <!-- targetProject:mapper對映檔案生成的位置 -->
33         <sqlMapGenerator targetPackage="com.mybatis.mapper"
34             targetProject=".\src">
35             <!-- enableSubPackages:是否讓schema作為包的字尾 -->
36             <property name="enableSubPackages" value="false" />
37         </sqlMapGenerator>
38         <!-- targetPackage:mapper介面生成的位置 -->
39         <javaClientGenerator type="XMLMAPPER"
40             targetPackage="com.mybatis.mapper" targetProject=".\src">
41             <!-- enableSubPackages:是否讓schema作為包的字尾 -->
42             <property name="enableSubPackages" value="false" />
43         </javaClientGenerator>
44         <!-- 指定資料庫表 -->
45         <table tableName="items"></table>
46         <table tableName="orders"></table>
47         <table tableName="orderdetail"></table>
48         <table tableName="t_user"></table>
49     </context>
50 </generatorConfiguration>

2.執行生成程式

GeneratorSqlmap.java的程式碼:

 1 import java.io.File;
 2 import java.util.ArrayList;
 3 import java.util.List;
 4 
 5 import org.mybatis.generator.api.MyBatisGenerator;
 6 import org.mybatis.generator.config.Configuration;
 7 import org.mybatis.generator.config.xml.ConfigurationParser;
 8 import org.mybatis.generator.internal.DefaultShellCallback;
 9 
10 public class GeneratorSqlmap {
11 
12     public void generator() throws Exception{
13 
14         List<String> warnings = new ArrayList<String>();
15         boolean overwrite = true;
16         //指定 逆向工程配置檔案
17         File configFile = new File("generatorConfig.xml"); 
18         ConfigurationParser cp = new ConfigurationParser(warnings);
19         Configuration config = cp.parseConfiguration(configFile);
20         DefaultShellCallback callback = new DefaultShellCallback(overwrite);
21         MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config,
22                 callback, warnings);
23         myBatisGenerator.generate(null);
24 
25     } 
26     public static void main(String[] args) throws Exception {
27         try {
28             GeneratorSqlmap generatorSqlmap = new GeneratorSqlmap();
29             generatorSqlmap.generator();
30         } catch (Exception e) {
31             e.printStackTrace();
32         }
33         
34     }
35 
36 }

上面這段程式碼在官方文件中的程式碼,裡面支援好多語言的,大家可以去官方看看。下面這張圖是從官方擷取的

配置好後,直接執行程式碼就會在配置的對應目錄生成對應的實體和mapper以及mapper.xml檔案。(類似hibernate的實體對映),當然除了這種方法生成,還可以下載mybatis_generator外掛生成。

執行完畢後,重新整理專案,就可以看到生成的對應檔案。

3.逆向工程注意事項

  mapper.xml檔案已存在時,如果進行重新生成則mapper.xml檔案內容不被覆蓋而是進行內容增加,結果會導致mybatis解析失敗。

  解決辦法:刪除原來的已經生成的mapper.xml檔案重新生成。

  mybais自動生成的實體entity以及mapper.java檔案不是內容追加而是直接覆蓋沒有問題。 

4.工程目錄

相關文章