mybatis入门基础(九)----逆向工程
2015-07-28 15:40
513 查看
一、什么是逆向工程
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 <?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.工程目录
相关文章推荐
- 用C#做一个简单纸牌游戏的程序
- ASIHTTPRequest异步请求
- iOS 消息推送原理及实现总结
- Java:重写equals()和hashCode()
- POJ3041 Asteroids(最小点覆盖)
- Executor UML 图谱
- Unity3d在移动设备上的音效有延迟的解决方案
- 查询列表后生成序号列的SQL语句
- 几个著名Java开源缓存框架介绍(OSCache,JSC)
- 合并本地git仓库
- android java.lang.NoSuchFieldError: R$id.xxx
- 虚函数问题
- hdu1233 还是畅通工程(prim算法)解题报告
- 数据结构与算法-线性表的定义与特点
- POJ3041 Asteroids(最小点覆盖)
- 菊花加载第三方--MBprogressHUD
- 数据结构与算法-线性表的定义与特点
- Java main方法
- python 得到web传递参数
- gof23 适配器模式