天天看點

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

前言

大家看看下面這個對話:

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

 ps:你...不會就是詭計多端的吳工吧? 如果恰好是,也沒事。

看完這一篇,學習隻有先知和後知,你看完學會了知道了,就行。

本篇内容:

根據資料庫的表 自動生成 代碼:

①相關的實體類(包含表字段注釋) ②相關mapper接口(包含增删改查) ③相關mapper.xml (包含增删改查)

不多說,開始實戰演練。

正文

先看下我們三步之後做了些啥,工程目錄結構 :

每個紅色框就是一步, 三個框,足矣。
Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

開始開始

前提

準備好資料庫、表(需要生成實體類、mapper的表):

這是示範實戰,就整2張表意思一下: 

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

表my_account

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

表my_user 

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

第一步 pom引入依賴

<dependencies>
        <!-- mybatis-generator -->
        <dependency>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-core</artifactId>
            <version>1.3.7</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.2.2</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>      

第二步 建立自動生成代碼配置

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

配置檔案一 ,用于生成代碼時連接配接資料庫拿表資料的。

generator.properties :

jdbc.driverClass=com.mysql.cj.jdbc.Driver
jdbc.connectionURL=jdbc:mysql://localhost:3306/my_test_db?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai
jdbc.userId=root
jdbc.password=123456      

配置檔案二 ,用于生成代碼時 指定生成的 目錄路徑、代碼函數等。

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>
    <properties resource="generator.properties"/>
    <context id="MySqlContext" targetRuntime="MyBatis3" defaultModelType="flat">
        <property name="beginningDelimiter" value="`"/>
        <property name="endingDelimiter" value="`"/>
        <property name="javaFileEncoding" value="UTF-8"/>
        <!-- 為模型生成序列化方法-->
        <plugin type="org.mybatis.generator.plugins.SerializablePlugin"/>
        <!-- 為生成的Java模型建立一個toString方法 -->
        <plugin type="org.mybatis.generator.plugins.ToStringPlugin"/>
        <!--生成mapper.xml時覆寫原檔案-->
        <plugin type="org.mybatis.generator.plugins.UnmergeableXmlMappersPlugin" />
        <!--可以自定義生成model的代碼注釋-->
        <commentGenerator type="com.demo.mybatisgen.util.CommentGenerator">
            <!-- 是否去除自動生成的注釋 true:是 : false:否 -->
            <property name="suppressAllComments" value="true"/>
            <property name="suppressDate" value="true"/>
            <property name="addRemarkComments" value="true"/>
        </commentGenerator>
        <!--配置資料庫連接配接-->
        <jdbcConnection driverClass="${jdbc.driverClass}"
                        connectionURL="${jdbc.connectionURL}"
                        userId="${jdbc.userId}"
                        password="${jdbc.password}">
            <!--解決mysql驅動更新到8.0後不生成指定資料庫代碼的問題-->
            <property name="nullCatalogMeansCurrent" value="true" />
        </jdbcConnection>
        <!--指定生成model的路徑-->
        <javaModelGenerator targetPackage="com.demo.mybatisgen.model" targetProject="src\main\java"/>
        <!--指定生成mapper.xml的路徑-->
        <sqlMapGenerator targetPackage="mybatis.mapper" targetProject="src\main\resources"/>
        <!--指定生成mapper接口的的路徑-->
        <javaClientGenerator type="XMLMAPPER" targetPackage="com.demo.mybatisgen.mapper"
                             targetProject="src\main\java"/>
        <!--生成全部表tableName設為%-->
        <table tableName="%" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false"
               enableSelectByExample="false" selectByExampleQueryId="false">

            <property name="useActualColumnNames" value="false"/>
            <property name="constructorBased" value="false"/>
            <generatedKey column="id" sqlStatement="JDBC" identity="true"/>
        </table>

    </context>
</generatorConfiguration>      

這個是使用備注添加器(第三步的内容):

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

第三步 建立代碼生成器 Generator

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

CommentGenerator.java:

import org.mybatis.generator.api.IntrospectedColumn;
import org.mybatis.generator.api.IntrospectedTable;
import org.mybatis.generator.api.dom.java.Field;
import org.mybatis.generator.internal.DefaultCommentGenerator;
import org.mybatis.generator.internal.util.StringUtility;

import java.util.Properties;


/**
 * @Author: JCccc
 * @Date: 2022-7-13 10:09
 * @Description: 注釋添加
 */
public class CommentGenerator extends DefaultCommentGenerator {
    private boolean addRemarkComments = false;

    /**
     * 設定使用者配置的參數
     */
    @Override
    public void addConfigurationProperties(Properties properties) {
        super.addConfigurationProperties(properties);
        this.addRemarkComments = StringUtility.isTrue(properties.getProperty("addRemarkComments"));
    }

    /**
     * 給字段添加注釋
     */
    @Override
    public void addFieldComment(Field field, IntrospectedTable introspectedTable,
                                IntrospectedColumn introspectedColumn) {
        String remarks = introspectedColumn.getRemarks();
        //根據參數和備注資訊判斷是否添加備注資訊
        if (addRemarkComments && StringUtility.stringHasValue(remarks)) {
            addFieldJavaDoc(field, remarks);
        }
    }

    /**
     * 給model的字段添加注釋
     */
    private void addFieldJavaDoc(Field field, String remarks) {
        //文檔注釋開始
        field.addJavaDocLine("/**");
        //擷取資料庫字段的備注資訊
        String[] remarkLines = remarks.split(System.getProperty("line.separator"));
        for (String remarkLine : remarkLines) {
            field.addJavaDocLine(" * " + remarkLine);
        }
        addJavadocTag(field, false);
        field.addJavaDocLine(" */");
    }

}      

Generator.java :

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;

import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;

/**
 * @Author: JCccc
 * @Date: 2022-7-13 10:09
 * @Description: 點它
 */
public class Generator {
    public static void main(String[] args) throws Exception {
        //MBG 執行過程中的警告資訊
        List<String> warnings = new ArrayList<String>();
        //當生成的代碼重複時,覆寫原代碼
        boolean overwrite = true;
        //讀取我們的 MBG 配置檔案
        InputStream is = Generator.class.getResourceAsStream("/generatorConfig.xml");
        ConfigurationParser cp = new ConfigurationParser(warnings);
        Configuration config = cp.parseConfiguration(is);
        is.close();

        DefaultShellCallback callback = new DefaultShellCallback(overwrite);
        //建立 MBG
        MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
        //執行生成代碼
        myBatisGenerator.generate(null);
        //輸出警告資訊
        for (String warning : warnings) {
            System.out.println(warning);
        }
    }
}      

好了,三步都完事了,再多一步當我輸。

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

然後點選一下代碼生成器Generator 的 main方法:

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

可以看到代碼生成了:

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

生成代碼的路徑就是  generatorConfig.xml 配置的:

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

看看實體:

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

看看interface mapper(大部分單表的增删改查函數都生成了):

Springboot 根據資料庫表自動生成實體類和Mapper,隻需三步

再看看mapper.xml (都有都有):

繼續閱讀