一、什么是逆向工程
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.工程目录
作者:阿赫瓦里
本文以学习、研究和分享为主,版权归作者和博客园共有,欢迎转载,如果文中有不妥或者错误的地方还望大神您不吝指出。如果觉得本文对您有所帮助不如【推荐】一下吧!如果你有更好的建议,不如留言一起讨论,共同进步! 再次感谢您耐心的读完本篇文章。
相关推荐
一、MyBatis简介 二、MyBatis-HelloWorld 三、MyBatis-全局配置文件 四、MyBatis-映射文件 五、MyBatis-动态SQL 六、MyBatis-缓存机制 ...七、MyBatis-Spring整合 ...八、MyBatis-逆向工程 九、MyBatis-工作原理
视频包含:mybatis入门;mybatis和hibernate的本质区别和应用场景;MyBatis配置文件编写,MyBatis动态SQL,MyBatis缓存机制,MyBatis-Spring整合,MyBatis逆向工程,MyBatis高级映射等等,适合入门级java学员(由于...
mybatis入门程序 用户的增、删、改、查 mybatis开发dao两种方法: ① :原始dao开发方法(程序需要编写dao接口和dao实现类)(掌握) ② :mybaits的mapper(代理)接口(相当于dao接口)代理开发方法(掌握)第二...
新手入门专用,赶紧来看看 (这里用的是springboot2.2.1.RELEASE,高版本可能容易出错)
自己学习总结的一套Spring+SpringMVC+MyBatis+逆向工程,自动生成Mapper以及Mapper.xml全套代码,全程带注解注释,简单明了,把复杂的问题简单化。适合初学者学习,也适合老手查询。
│ │ 第一章第1节: 03-mybatis入门.mp4 │ │ 第一章第1节: 04-mybatis基础应用之mapper代理开发方式.mp4 │ │ 第一章第1节: 06-mybatis基础应用之全局配置文件.mp4 │ │ 第一章第1节: 08-mybatis...
• 逆向工程 • PageHelper分页插件 • 注解开发 主键返回(mybatis的自增主键或者非自增主键) • 批量查询 • 动态传参 • 查询缓存(一级缓存、二级缓存) • 延迟加载(侵入式延迟加载、深度延迟加载) • 关联...
使用mybatis-generator逆向工程来生成相应的po和mapper 使用mybatis能够连接数据库并查询 新增集成log4j2 --2017-05-25 异步打印日志 新增myBatis分页插件pageHelper --2017-05-31 集成spring thymeleaf、security -...
MyBatis是一个优秀的Java ORM框架,本课程从MyBatis环境搭建讲起,详细讲述的MyBatis的CRUD操作、接口编程、SessionFactory、全局配置、关联映射、动态SQL、缓存和逆向工程等内容。
1 Mybatis入门 1 1.1 单独使用jdbc编程问题总结 1 1.1.1 jdbc程序 1 1.1.2 jdbc编程步骤: 2 1.1.3 jdbc问题总结如下: 3 1.2 MyBatis介绍 3 1.3 Mybatis架构 3 1.4 mybatis下载 4 1.5 创建mysql数据库 5 1.6 ...
动态sql-关联查询.myBatis整合spring,逆向工程 14-SpringMVC(学习2天) SpringMvc_day01.spring入门-springMVC三大核心器(视图解析器,处理器映射器and适配器).springMvc整合myBatis SpringMvc_day02高级参数....
使用Idea工具利用MyBatis-Maven完成逆向工程代码生成,项目简单,是一个SSM的入门案例