mybatis逆向工程使用

Posted xiafeiyong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mybatis逆向工程使用相关的知识,希望对你有一定的参考价值。

下面给大家介绍一种偷懒的生成工具使用--mybatis-generator,使用此插件可以从数据库生成指定表格对应的实体类、mapper接口以及对应的xml文件(包含一些常用的方法实现)。

首先是通过maven添加插件引用

 

  1.  
    <plugin>
  2.  
    <groupId>org.mybatis.generator</groupId>
  3.  
    <artifactId>mybatis-generator-maven-plugin</artifactId>
  4.  
    <version>1.3.2</version>
  5.  
    <configuration>
  6.  
    <!--配置文件的位置-->
  7.  
    <configurationFile>src/main/resources/generatorConfig.xml</configurationFile>
  8.  
    <verbose>true</verbose>
  9.  
    <overwrite>true</overwrite>
  10.  
    </configuration>
  11.  
    <executions>
  12.  
    <execution>
  13.  
    <id>Generate MyBatis Artifacts</id>
  14.  
    <goals>
  15.  
    <goal>generate</goal>
  16.  
    </goals>
  17.  
    </execution>
  18.  
    </executions>
  19.  
    <dependencies>
  20.  
    <dependency>
  21.  
    <groupId>org.mybatis.generator</groupId>
  22.  
    <artifactId>mybatis-generator-core</artifactId>
  23.  
    <version>1.3.2</version>
  24.  
    </dependency>
  25.  
    </dependencies>
  26.  
    </plugin>

 

新建配置文件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.  
    <generatorConfiguration>
  6.  
    <!--mysql 连接数据库jar 这里选择自己本地位置-->
  7.  
    <classPathEntry location="D:maven epositorymysqlmysql-connector-java5.1.34mysql-connector-java-5.1.34.jar" />
  8.  
    <context id="testTables" targetRuntime="MyBatis3">
  9.  
    <commentGenerator>
  10.  
    <!-- 是否去除自动生成的注释 true:是 : false:否 -->
  11.  
    <property name="suppressAllComments" value="true" />
  12.  
    </commentGenerator>
  13.  
    <!--数据库连接的信息:驱动类、连接地址、用户名、密码 -->
  14.  
    <jdbcConnection driverClass="com.mysql.jdbc.Driver"
  15.  
    connectionURL="jdbc:mysql://localhost:3306/test?serverTimezone=UTC" userId="root"
  16.  
    password="123456">
  17.  
    </jdbcConnection>
  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.example.demo.entry"
  26.  
    targetProject="src/main/java">
  27.  
    <!-- enableSubPackages:是否让schema作为包的后缀 -->
  28.  
    <property name="enableSubPackages" value="false" />
  29.  
    <!-- 从数据库返回的值被清理前后的空格 -->
  30.  
    <property name="trimStrings" value="true" />
  31.  
    </javaModelGenerator>
  32.  
    <!-- targetProject:mapper映射文件生成的位置
  33.  
    如果maven工程只是单独的一个工程,targetProject="src/main/java"
  34.  
    若果maven工程是分模块的工程,targetProject="所属模块的名称",例如:
  35.  
    targetProject="ecps-manager-mapper",下同-->
  36.  
    <sqlMapGenerator targetPackage="mapXml"
  37.  
    targetProject="src/main/resources">
  38.  
    <!-- enableSubPackages:是否让schema作为包的后缀 -->
  39.  
    <property name="enableSubPackages" value="false" />
  40.  
    </sqlMapGenerator>
  41.  
    <!-- targetPackage:mapper接口生成的位置 -->
  42.  
    <javaClientGenerator type="XMLMAPPER"
  43.  
    targetPackage="com.example.demo.mapper"
  44.  
    targetProject="src/main/java">
  45.  
    <!-- enableSubPackages:是否让schema作为包的后缀 -->
  46.  
    <property name="enableSubPackages" value="false" />
  47.  
    </javaClientGenerator>
  48.  
    <!-- 指定数据库表 -->
  49.  
    <table schema="" tableName="demo2"></table>
  50.  
    </context>
  51.  
    </generatorConfiguration>

 

配置文件需配置数据库jar包位置,生成的文件存放位置等信息

IEDA配置运行选项:

技术分享图片

运行环境配置中新增maven选项,Command Line项设置值为  mybatis-generator:generate -e

最后,选中generatorConfig.xml配置文件,以新建的方式运行

技术分享图片

可以看到对应的文件已经生成,而且mapper中也生成了一些基础的方法

MyEclipse中也有类似的无须maven引入的插件,可以自行百度了解其安装方法

注意:

在上面的配置文件,有一个严重的问题,就是

 

  1.  
    <commentGenerator>
  2.  
    <!-- 是否去除自动生成的注释 true:是 : false:否 -->
  3.  
    <property name="suppressAllComments" value="true" />
  4.  
    </commentGenerator>

这里的注释设置,最好设置为false,因为第二次更新生成代码的时候,是会根据注释中@mbggenerated来生成,如果去除自动生成的注释,会引起XML代码重复生成的问题,从而导致启动报错。

还有一个问题,在Maven插件设置中设置了

 

<overwrite>true</overwrite>

所以每次重新生成,Mapper会被覆盖,这样自己写的接口会被清除,myeclipse中使用插件安装是可以避免这个问题的,但是IDEA不行,最近在找方法解决中。。。

 

以上是关于mybatis逆向工程使用的主要内容,如果未能解决你的问题,请参考以下文章

MyBatis学习15MyBatis的逆向工程生成代码

使用Mybatis的逆向工程自动生成代码

Mybatis逆向工程(代码生成器)及其简单使用——及其报错处理

MyBatis逆向工程

Mac下使用mybatis逆向工程遇到的问题

在IDEA中使用MyBatis Generator逆向工程生成代码