MyBatis 的逆向工程

MyBatis

2016-09-14

100

76

一、什么是逆向工程  

      mybaits需要程序员自己编写sql语句,mybatis官方提供逆向工程 可以针对单表自动生成mybatis执行所需要的代码(mapper.java,mapper.xml、po..)

      实际开发中,常用的逆向工程方式:由数据库的表生成java代码。

二、下载逆向工程

  去官网下载逆向工程,截至今天最新版本是1.3.3.    官方逆向工程文档

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

                                                 mybatis学习资料(中英文文档,参数常见配置等).rar

三、使用方法

1.生成代码配置文件

 generatorConfig.xml的配置

 1 
 2 
 5 
 6 
 7     
 8         
 9             
10             
11         
12         
13         
16         
17 
18         
20         
21             
22         
23 
24         
25         
27             
28             
29             
30             
31         
32         
33         
35             
36             
37         
38         
39         
41             
42             
43         
44         
45
46
47
48
49     
50 



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 warnings = new ArrayList();
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.工程目录

打赏一个呗~~

关注我
长按二维码可识别关注
微信号:xwintop
微信号xwintop


追风

爱一个人就像执着于一种梦想,没有值不值得,只有愿不愿意···

关注我
长按二维码可识别关注
微信号:xwintop
微信号xwintop


关注我
长按二维码可识别关注
微信号:xwintop
微信号xwintop