`
2277259257
  • 浏览: 518357 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

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

作者:阿赫瓦里
本文以学习、研究和分享为主,版权归作者和博客园共有,欢迎转载,如果文中有不妥或者错误的地方还望大神您不吝指出。如果觉得本文对您有所帮助不如【推荐】一下吧!如果你有更好的建议,不如留言一起讨论,共同进步! 再次感谢您耐心的读完本篇文章。
分享到:
评论

相关推荐

    MyBatis入门以及提高

    【MyBatis入门以及提高】 在Java EE框架中,MyBatis是一个广泛使用的持久层框架,它极大地简化了原生JDBC编程的繁琐过程。MyBatis的核心在于输入映射和输出映射,以及动态SQL,这些特性使得SQL的编写和维护变得更加...

    MyBatis快速入门

    一、MyBatis简介 二、MyBatis-HelloWorld 三、MyBatis-全局配置文件 四、MyBatis-映射文件 五、MyBatis-动态SQL 六、MyBatis-缓存机制 ...七、MyBatis-Spring整合 ...八、MyBatis-逆向工程 九、MyBatis-工作原理

    mybatis-generator-for-imooc.zip

    在MyBatis Generator中,逆向工程是指从数据库表结构中自动生成对应的Java实体类、Mapper接口和XML配置文件,减少了大量手动编码的工作。 3. **MyBatis Generator配置**:MBG的主配置文件(通常为`generatorConfig....

    4.2mybatis入门教程(一)

    MyBatis 提供的逆向工程工具可以自动生成 Mapper XML 文件和对应的 Java POJO 类,简化开发工作。 总之,MyBatis 作为一款强大的持久层框架,极大地提高了开发效率,降低了 SQL 相关操作的复杂性,使得开发者能够...

    mybatis入门到精通详解

    视频包含:mybatis入门;mybatis和hibernate的本质区别和应用场景;MyBatis配置文件编写,MyBatis动态SQL,MyBatis缓存机制,MyBatis-Spring整合,MyBatis逆向工程,MyBatis高级映射等等,适合入门级java学员(由于...

    mybatis入门教程(二)

    #### 逆向工程 - **目的**:简化初始代码生成过程,根据数据库表结构自动生成相应的 POJO 类、Mapper 文件以及 Dao 接口等。 - **工具**:如 MyBatis Generator,可以根据数据库表自动生成相应的代码。 #### 订单...

    mybatis-jar包

    5. **逆向工程**:逆向工程是MyBatis提供的一种自动化工具,可以从数据库表生成Java实体类、Mapper接口和XML映射文件,极大地简化了开发过程。这通常涉及到MyBatis Generator,一个独立的工具,可以自定义配置来生成...

    MyBatis3.2.4完全自学手册

    MyBatis逆向工程工具可以帮助开发者自动生成数据库表对应的Java实体类、Mapper接口以及XML映射文件等,极大地提高了开发效率。 总结起来,MyBatis是一个功能强大、易于使用的持久层框架,通过其丰富的特性和灵活的...

    Spring+SpringMVC+MyBatis入门神器

    自己学习总结的一套Spring+SpringMVC+MyBatis+逆向工程,自动生成Mapper以及Mapper.xml全套代码,全程带注解注释,简单明了,把复杂的问题简单化。适合初学者学习,也适合老手查询。

    JavaEE企业级分布式高级架构师018期 94G

    │ │ 第一章第1节: 03-mybatis入门.mp4 │ │ 第一章第1节: 04-mybatis基础应用之mapper代理开发方式.mp4 │ │ 第一章第1节: 06-mybatis基础应用之全局配置文件.mp4 │ │ 第一章第1节: 08-mybatis...

    mybatis第二天课堂笔记

    #### 九、逆向工程 - **工具介绍**:如 MyBatis Generator 可以根据数据库表结构生成对应的 POJO、Mapper XML 和 Mapper 接口。 #### 十、订单商品数据模型分析 - **用户表 user**:记录用户的个人信息。 - **...

    mybatis笔记.docx

    - **MyBatis 逆向工程**: 自动生成 DAO 层代码,简化开发工作。 总的来说,MyBatis 是一个强大且灵活的持久层框架,它通过将 SQL 语句与 Java 代码分离,提高了代码的可读性和可维护性。通过学习 MyBatis,开发者...

    mybatis笔记文档

    #### 三、MyBatis入门程序 ##### 1. 环境搭建 - **Java环境**:JDK 1.7.0_72。 - **IDE**:Eclipse Indigo。 - **数据库**:MySQL 5.1。 ##### 2. 需求分析 - 根据用户ID(主键)查询用户信息。 - 根据用户名...

    mybatis学习文档资料

    - **9.2 下载逆向工程**:介绍如何下载并安装MyBatis的逆向工程工具。 - **9.3 使用方法**: - **9.3.1 运行逆向工程**:启动逆向工程工具。 - **9.3.2 生成代码配置文件**:配置生成代码所需的各项参数。 - **...

    mybatis从入门到精通(第一节)

    • 逆向工程 • PageHelper分页插件 • 注解开发 主键返回(mybatis的自增主键或者非自增主键) • 批量查询 • 动态传参 • 查询缓存(一级缓存、二级缓存) • 延迟加载(侵入式延迟加载、深度延迟加载) • 关联...

    mybatis第一天课程文档

    ### MyBatis基础知识点 #### 一、MyBatis简介...5. **逆向工程工具**:自动为现有数据库生成对应的Java实体类、映射文件等。 通过这些高级特性的学习和实践,开发者可以更加高效地使用MyBatis来开发复杂的应用程序。

    mybatis学习笔记

    MyBatis入门 ##### 1.1 单独使用JDBC编程问题总结 - **JDBC程序示例**:通过一个具体的示例展示了如何使用JDBC连接数据库并执行SQL查询。 - 加载数据库驱动 - 获取数据库连接 - 准备SQL语句 - 设置参数 - 执行...

    Mybatis 学习笔记

    - **Mybatis 逆向工程**:自动生成 POJO 类、Mapper 接口和 XML 映射文件,快速建模。 在企业开发中,Mybatis 因其易用性和灵活性,常被用于中小型项目的持久层实现。通过学习 Mybatis,你可以更高效地管理数据库...

    MyBatis配套资料.rar

    5. **MyBatis基础**:`MyBatis.rar`和`MyBatis入门示例.rar`应该是MyBatis的基础介绍和简单示例,适合初学者快速上手。 6. **MyBatis笔记**:`MyBatis笔记.rar`可能是个人或社区整理的学习笔记,包含了使用MyBatis...

Global site tag (gtag.js) - Google Analytics