mybaits須要程序員本身編寫sql語句,mybatis官方提供逆向工程 能夠針對單表自動生成mybatis執行所須要的代碼(mapper.java,mapper.xml、po..)java
實際開發中,經常使用的逆向工程方式:由數據庫的表生成java代碼。mysql
去官網下載逆向工程,截至今天最新版本是1.3.3. 官方逆向工程文檔git
我所用的是1.3.2版本的,下載地址: mybatis_generator所用jar包.zip程序員
mybatis學習資料(中英文文檔,參數常見配置等).rargithub
1.生成代碼配置文件sql
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.執行生成程序api
GeneratorSqlmap.java的代碼:mybatis
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 }
上面這段代碼在官方文檔中的代碼,裏面支持好多語言的,你們能夠去官方看看。下面這張圖是從官方截取的oracle
配置好後,直接運行代碼就會在配置的對應目錄生成對應的實體和mapper以及mapper.xml文件。(相似hibernate的實體映射),固然除了這種方法生成,還能夠下載mybatis_generator插件生成。
執行完畢後,刷新項目,就能夠看到生成的對應文件。
3.逆向工程注意事項
mapper.xml文件已存在時,若是進行從新生成則mapper.xml文件內容不被覆蓋而是進行內容增長,結果會致使mybatis解析失敗。
解決辦法:刪除原來的已經生成的mapper.xml文件從新生成。
mybais自動生成的實體entity以及mapper.java文件不是內容追加而是直接覆蓋沒有問題。
4.工程目錄