mybatis入门基础(九)----逆向工程


一、什么是逆向工程  

      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.工程目录


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM