SpringBoot圖文教程8 — SpringBoot集成MBG「代碼生成器」

有天上飛的概念,就要有落地的實現java

  • 概念十遍不如代碼一遍,朋友,但願你把文中全部的代碼案例都敲一遍mysql

  • 先贊後看,養成習慣git

SpringBoot 圖文教程系列文章目錄web

  1. SpringBoot圖文教程1「概念+案例 思惟導圖」「基礎篇上」
  2. SpringBoot圖文教程2—日誌的使用「logback」「log4j」
  3. SpringBoot圖文教程3—「‘初戀’情結」集成Jsp
  4. SpringBoot圖文教程4—SpringBoot 實現文件上傳下載
  5. SpringBoot圖文教程5—SpringBoot 中使用Aop
  6. SpringBoot圖文教程6—SpringBoot中過濾器的使用
  7. SpringBoot圖文教程7—SpringBoot攔截器的使用姿式這都有

前言

在使用Mybatis進行項目開發的時候,最繁瑣的事情就是實體類,dao接口,mapper.xml文件的編寫,幾乎每一個表都須要對應寫一套,而且大部分的工做量都在最基本的增刪改查上。若是表中的字段進行了修改,那麼實體類,mapper文件甚至dao接口都要進行修改。面試

天下苦mapper文件久矣,因而Mybatis官方推薦了一個Mybatis代碼生成器(MBG)來救民於水火之中。sql

Mybatis 代碼生成器

MBG

MBG 全稱 MyBatis Generator,能夠用來生成Mybatis開發相關的代碼,包括基本增刪改查的實體類,dao接口和mapper文件。而且 MBG 工具支持全部版本的Mybatis。數據庫

官方文檔地址:mybatis.org/generator/mybatis

SpringBoot 集成 MBG

本文代碼會在一個SpringBoot+Mybatis的空項目中進行,若有須要請去Git倉庫下載:gitee.com/bingqilinpe…app

1.導入依賴

SpringBoot中使用MBG須要在導入MBG依賴的同時導入MBG的啓動插件。
MBG的依賴dom

<!--MybatisGenerator的依賴jar包-->
<dependency>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-core</artifactId>
            <version>1.3.2</version>
        </dependency>
複製代碼

MBG的啓動插件

<!--MybatisGenerator的啓動插件-->
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.2</version>
                <!--jar包去生成對應類 須要鏈接數據庫 數據鏈接的版本和項目中的一致-->
                <dependencies>
                    <dependency>
                        <groupId>mysql</groupId>
                        <artifactId>mysql-connector-java</artifactId>
                        <version>5.1.38</version>
                    </dependency>
                </dependencies>

                <configuration>
                    <!--MBG配置文件的路徑 -->
                    <configurationFile>${basedir}/src/main/resources/generatorConfig.xml</configurationFile>
                    <overwrite>true</overwrite>
                </configuration>
            </plugin>
複製代碼

注意:

  1. 插件中的 mysql-connector-java 版本和項目中版本號一致
  2. configurationFile 配置的是 MBG配置文件的地址 src/main/resources

2.導入並編寫MBG配置文件

導入依賴以後,須要在SpringBoot resources目錄下導入 MBG 的配置文件 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="test" targetRuntime="MyBatis3">
        <plugin type="org.mybatis.generator.plugins.EqualsHashCodePlugin"></plugin>  
        <plugin type="org.mybatis.generator.plugins.SerializablePlugin"></plugin> 
        <plugin type="org.mybatis.generator.plugins.ToStringPlugin"></plugin>

        <commentGenerator>
            <!-- 這個元素用來去除指定生成的註釋中是否包含生成的日期 false:表示包含 -->
            <!-- 若是生成日期,會形成即便修改一個字段,整個實體類全部屬性都會發生變化,不利於版本控制,因此設置爲true -->
            <property name="suppressDate" value="true" />
            <!-- 是否去除自動生成的註釋 true:是 : false:否 -->
            <property name="suppressAllComments" value="true" />

        </commentGenerator>

        <!--數據庫連接URL,用戶名、密碼 -->
        <jdbcConnection
                driverClass="com.mysql.jdbc.Driver"
                connectionURL="jdbc:mysql://localhost/demo"
                userId="root"
                password="123456">

        </jdbcConnection>

        <javaTypeResolver>
            <property name="forceBigDecimals" value="false" />
        </javaTypeResolver>

        <!-- 生成實體類的包名和位置 -->
        <javaModelGenerator targetPackage="com.lu.entity"
            targetProject="src/main/java">

            <property name="enableSubPackages" value="true" />
            <property name="trimStrings" value="true" />
        </javaModelGenerator>

        <!--生成映射文件的包名和位置  com/lu/mapper-->
        <sqlMapGenerator targetPackage="mapper"
            targetProject="src/main/resources">

            <property name="enableSubPackages" value="true" />
        </sqlMapGenerator>

        <!-- 生成DAO的包名和位置 mybatis兩種開發模式 xml 註解式-->
        <javaClientGenerator type="XMLMAPPER"
            targetPackage="com.lu.dao" targetProject="src/main/java">

            <property name="enableSubPackages" value="true" />
        </javaClientGenerator>

        <!-- 要生成哪些表 -->
        <table tableName="user" domainObjectName="User"
               enableCountByExample="false" enableUpdateByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               selectByExampleQueryId="false">

        </table>



    </context>
</generatorConfiguration>
複製代碼

重點配置 !!!

在配置文件中有一下配置須要使用者根據本身的狀況進行配置

  1. 數據庫鏈接參數 修改成本身數據庫的鏈接參數

  2. dao接口 實體類 mapper文件生成位置 包結構的配置

注意:生成位置和包結構參數根據本身實際狀況進行修改,其餘的內容不須要修改

  1. 配置 要生成哪些表 對應的實體類 dao接口 和 mapper文件

注意:除了以上三個配置,其餘配置均可以沒必要修改

3.經過插件啓動可生成代碼

運行插件,生成代碼以下:

  • 實體類

  • dao接口

  • mapper文件

總結

Tips:本文示例代碼項目地址爲:gitee.com/bingqilinpe…

恭喜你完成了本章的學習,爲你鼓掌!若是本文對你有幫助,請幫忙點贊,評論,轉發,這對做者很重要,謝謝。

讓咱們再次回顧本文的學習目標

  • 掌握SpringBoot中MBG的使用

要掌握SpringBoot更多的用法,請持續關注本系列教程。

求關注,求點贊,求轉發

歡迎關注本人公衆號:鹿老師的Java筆記,將在長期更新Java技術圖文教程和視頻教程,Java學習經驗,Java面試經驗以及Java實戰開發經驗。

相關文章
相關標籤/搜索