MyBatis Generator 是 MyBatis 提供的一個代碼生成工具。可以幫我們生成 表對應(yīng)的持久化對象(po)、操作數(shù)據(jù)庫的接口(dao)、CRUD sql的xml(mapper)。
MyBatis Generator 是一個獨(dú)立工具,你可以下載它的jar包來運(yùn)行、也可以在 Ant 和 maven 運(yùn)行。
使用環(huán)境

引入插件

配置插件
MyBatis Generator 插件需要根據(jù)一個 MyBatis Generator config 文件,來具體運(yùn)行
配置如下,版本我用的是目前最新的版本 1.4.0

配置 MyBatis Generator Config
MyBatis Generator 插件啟動后,會根據(jù)你在 pom 中配置都路徑找到該配置文件。
這個配置文件才是詳細(xì)都配置 MyBatis Generator 生成代碼的各種細(xì)節(jié)。
其中最重要的就是 context ,你的配置文件至少得包含一個context
<?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>
<classPathEntry
location="C:\Users\redhood\3D Objects\repository\mysql\mysql-connector-java\8.0.19\mysql-connector-java-8.0.19.jar"/>
<context id="mysql" defaultModelType="flat" targetRuntime="MyBatis3">
<!-- 生成的 Java 文件的編碼 -->
<property name="javaFileEncoding" value="UTF-8"/>
<!-- 格式化 Java 代碼 -->
<property name="javaFormatter" value="org.mybatis.generator.api.dom.DefaultJavaFormatter"/>
<!-- 格式化 XML 代碼 -->
<property name="xmlFormatter" value="org.mybatis.generator.api.dom.DefaultXmlFormatter"/>
<!-- 生成mysql帶有分頁的sql的插件 這個可以自己寫,-->
<!-- <plugin type="generator.MysqlPaginationPlugin" />-->
<plugin type="org.mybatis.generator.plugins.ToStringPlugin"/>
<plugin type="org.mybatis.generator.plugins.SerializablePlugin"/>
<!-- 自定義的注釋規(guī)則,繼承 DefaultCommentGenerator 重寫 一些方法 -->
<commentGenerator type="com.generator.NewbatisGenerator">
<!-- 是否去除自動生成日期的注釋 true:是 : false:否 -->
<property name="suppressDate" value="true"/>
<!-- 是否去除所有自動生成的注釋 true:是 : false:否 -->
<property name="suppressAllComments" value="true"/>
</commentGenerator>
<jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/cathome_demo?useSSL=false&characterEncoding=utf8&serverTimezone=UTC"
userId="root"
password="12345">
<!-- 防止找錯庫-->
<property name="nullCatalogMeansCurrent" value="true"/>
<!-- 設(shè)置 useInformationSchema 屬性為 true -->
<property name="useInformationSchema" value="true"/>
</jdbcConnection>
<!--生成entity類存放位置-->
<javaModelGenerator targetPackage="com.redhood.backend.cathome.test_generator.entity"
targetProject="src\main\java">
<property name="enableSubPackages" value="true"/>
<property name="trimStrings" value="true"/>
<!-- 是否對modal添加構(gòu)造函數(shù) -->
<property name="constructorBased" value="true"/>
<!-- 建立modal對象是否不可改變 即生成的modal對象不會有setter方法,只有構(gòu)造方法 -->
<property name="immutable" value="false"/>
</javaModelGenerator>
<!--生成映射文件存放位置-->
<sqlMapGenerator targetPackage="com.redhood.backend.cathome.test_generator.mapper"
targetProject="src\main\java">
<property name="enableSubPackages" value="true"/>
</sqlMapGenerator>
<!--生成Dao類存放位置-->
<javaClientGenerator type="XMLMAPPER" targetPackage="com.redhood.backend.cathome.test_generator.dao"
targetProject="src\main\java">
<property name="enableSubPackages" value="true"/>
</javaClientGenerator>
<table schema="cathome_demo" tableName="user" domainObjectName="User">
</table>
</context>
</generatorConfiguration>
使用 MyBatis Generator
配置好后,雙擊 maven 中的 MyBatis Generator 運(yùn)行

也可以使用工具類運(yùn)行
public class MybatisGeneratorUtil {
/**
* 通過執(zhí)行本方法,調(diào)用 Mybatis Generator 工具,生成相應(yīng)代碼。
* 避免 Eclipse、IDEA 之間插件使用的差異。
* @param args
* @return
*/
public static void main(String[] args) throws Exception {
List<String> warnings = new ArrayList<>();
String configFilePath = MybatisGeneratorUtil.class.getClassLoader().getResource("generatorConfig.xml").getFile(); // mybatis-generator.xml 配置文件放在 resources 目錄里。
File configFile = new File(configFilePath);
ConfigurationParser parser = new ConfigurationParser(warnings);
Configuration config = parser.parseConfiguration(configFile);
DefaultShellCallback callback = new DefaultShellCallback(true); // 存在則覆蓋
MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
myBatisGenerator.generate(null);
}
}
生成文件
