Eclipse中使用Mybatis Generator自動生成POJO類、mapper類等


一、首先去Eclipse Marketplace 中安裝插件Mybatis Generator,如果安裝了,如下圖所示,我已經安裝過了。

 

二、pom.xml文件除了正常的依賴,增加mybatis-generator-core的依賴(我使用的是1.3.2版本)

<dependency>
  <groupId>org.mybatis.generator</groupId>
  <artifactId>mybatis-generator-core</artifactId>
   <version>1.3.2</version>
</dependency>

三、增加一個編譯插件

<plugin>
  <groupId>org.mybatis.generator</groupId>
  <artifactId>mybatis-generator-maven-plugin</artifactId>
  <version>1.3.2</version>
  <configuration>
    <verbose>true</verbose>
    <overwrite>true</overwrite>
  </configuration>
</plugin>    

四、完整的pom.xml配置如下:

 

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>cn.com.winson.springboot</groupId>
    <artifactId>maven-springboot</artifactId>
    <packaging>war</packaging>
    <version>0.0.1-SNAPSHOT</version>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.17.RELEASE</version>
        <relativePath />
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-core</artifactId>
            <version>1.3.2</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.2</version>
                <configuration>
                    <verbose>true</verbose>
                    <overwrite>true</overwrite>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

 

五、新建一個配置文件:generatorConfig.xml

 

六、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>
    <!-- 配置mysql的驅動(本地倉庫中mysql的jar全路徑) -->
    <classPathEntry
        location="D:\maven\repository\mysql\mysql-connector-java\5.1.46\mysql-connector-java-5.1.46.jar" />
    <context id="mysqlTables" targetRuntime="MyBatis3">

        <commentGenerator>
            <property name="suppressAllComments" value="true" />
        </commentGenerator>
    
        <!-- 配置數據庫連接 -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
            connectionURL="jdbc:mysql://localhost:3306/test" 
            userId="root"
            password="root">
        </jdbcConnection>

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

        <!-- 生成model模型,對應的包,存放位置可以指定具體的路徑,如/ProjectName/src,也可以使用MAVEN來自動生成 -->
        <javaModelGenerator targetPackage="cn.com.winson.domin"
            targetProject="springboot-mybatis/src/main/java">
            <property name="enableSubPackages" value="true" />
            <property name="trimStrings" value="true" />
        </javaModelGenerator>

        <!--對應的xml mapper文件 ,目前沒有跟dao接口同一目錄下,可自行調整與dao同目錄-->
        <sqlMapGenerator targetPackage="mybatis"
            targetProject="springboot-mybatis/src/main/resources">
            <property name="enableSubPackages" value="true" />
        </sqlMapGenerator>

        <!-- 對應的dao接口 -->
        <javaClientGenerator type="XMLMAPPER"
            targetPackage="cn.com.winson.dao" targetProject="springboot-mybatis/src/main/java">
            <property name="enableSubPackages" value="true" />
        </javaClientGenerator>

        <!-- 這里是數據庫的表名t_user 以及 POJO類的名字User -->
        <table tableName="t_user" domainObjectName="User"
            enableCountByExample="false" enableSelectByExample="false"
            enableUpdateByExample="false" enableDeleteByExample="false">
        </table>
    </context>

</generatorConfiguration>

  注意:這里有一個大坑,很多博客都沒有提到,有一個屬性targetProject,它的值必須帶上工程名(Project_Name):targetProject="springboot-mybatis/src/main/java",否則后面你會無法運行自動生成文件的程序

 

七、運行配置文件,自動生成mapper接口、model類、及mapper.xml,注意,不用用run as ->Run MyBatis Generator來操作,如果有錯,它不會報出來。

        

不要用下圖方法操作:

 

 八、錯誤分析,下面的錯誤就是因為屬性targetProject沒有帶上工程名(Project_Name)導致的,這是使用上圖第一種方法運行配置文件報的錯,第二種方法不會有報錯提示,這里不做演示。

 九、正確執行配置文件以后,自動生成的目錄結構如下圖:

 

十、總結:

  好了,這就是利用插件自動生成文件的方法,要特別注意我所提到的坑,很多帖子沒有提到,我在試驗時候,花了好長時間才發現這個問題,瀏覽了很多帖子,本貼子沒有深度講解各模塊的作用及原理,但是你們可以直接把代碼拿來復用,節約你們摸索的時間,以后有空,你們再慢慢理解。

代碼地址:https://gitee.com/top_one/SpringBoot_Generator_MyBatis.git


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM