MyBatis逆向工程generator自動代碼生成

概述

名字聽起來挺高大上的 但實際上所謂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();
        }
    }
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章