概述
名字听起来挺高大上的 但实际上所谓MyBatis逆向工程 就是通过相应的插件自动生成MyBatis数据库连接的一些文件(例如mapper、pojo…)
以提高工作效率
步骤
首先 导入依赖:
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.5</version>
</dependency>
创建一个配置文件generatorConfig.xml:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
<context id="MyTables" targetRuntime="MyBatis3">
<commentGenerator>
<!-- 是否去除自动生成的注释 -->
<property name="suppressAllComments" value="true"/>
</commentGenerator>
<!-- Mysql数据库连接信息 -->
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/demo"
userId="root"
password="123456">
</jdbcConnection>
<!-- 默认为false 将JDBC DECIMAL和NUMERIC类型解析为Integer
若为true 则将JDBC DECIMAL和NUMERIC类型解析为java.math.BigDecimal -->
<javaTypeResolver >
<property name="forceBigDecimals" value="false" />
</javaTypeResolver>
<!-- 生成POJO类的位置 -->
<javaModelGenerator targetPackage="net.zjitc.pojo" targetProject=".\src\main\java">
<!-- 是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false" />
<!-- 从数据库返回的值清理前后的空格 -->
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!-- mapper映射文件生成的位置 -->
<sqlMapGenerator targetPackage="net.zjitc.mapper" targetProject=".\src\main\java">
<!-- 是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false" />
</sqlMapGenerator>
<!-- mapper接口生成的的位置 -->
<javaClientGenerator type="XMLMAPPER" targetPackage="net.zjitc.mapper" targetProject=".\src\main\java">
<!-- 是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false" />
</javaClientGenerator>
<!-- 指定要自动生成的数据表 -->
<table schema="" tableName="tb_a"/>
<table schema="" tableName="tb_b"/>
<table schema="" tableName="tb_c"/>
<table schema="" tableName="tb_d"/>
</context>
</generatorConfiguration>
最后 创建一个启动类:
运行main方法 即可开始生成
import java.io.File;
import java.util.*;
import org.mybatis.generator.api.MyBatisGenerator;
import org.mybatis.generator.config.Configuration;
import org.mybatis.generator.config.xml.ConfigurationParser;
import org.mybatis.generator.internal.DefaultShellCallback;
public class GeneratorTest {
public void generator() throws Exception {
List<String> warnings = new ArrayList<String>();
boolean overwrite = true;
// 指定配置文件的位置
File configFile = new File("F:\\IdeaProjects\\xxx\\src\\main\\resources\\generatorConfig.xml");
ConfigurationParser cp = new ConfigurationParser(warnings);
Configuration config = cp.parseConfiguration(configFile);
DefaultShellCallback callback = new DefaultShellCallback(overwrite);
MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
myBatisGenerator.generate(null);
}
// 生成代码
public static void main(String[] args) {
try {
GeneratorTest generatorTest = new GeneratorTest();
generatorTest.generator();
} catch (Exception e) {
e.printStackTrace();
}
}
}