zoukankan      html  css  js  c++  java
  • 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.工程目录

  • 相关阅读:
    矿场和矿池有什么区别?
    石墨烯技术到底是什么?
    区块链技术如何解决网络犯罪?
    区块链+AI将给区块链带来怎样的改变?
    区块链技术具体包含哪些方面?
    2018年加密货币税率为0%的国家盘点
    what??|诞生才一年的BCH竟面临硬分叉的抉择
    币圈黑客在偷到币后是如何销脏的?
    选择器
    纯js+html+css实现模拟时钟
  • 原文地址:https://www.cnblogs.com/selene/p/4650863.html
Copyright © 2011-2022 走看看