IDEA 中使用MyBatis-generator 自動生成MyBatis代碼

0.在Intellij IDEA建立maven項目

1. 在maven項目的pom.xml 添加mybatis-generator-maven-plugin 插件

複製代碼
<build>  
  <finalName>xxx</finalName>  
  <plugins>  
    <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>  
複製代碼

2. 在maven項目下的src/main/resources 目錄下創建名爲 generatorConfig.xml的配置文件,做爲mybatis-generator-maven-plugin 插件的執行目標,模板以下:

<?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"></properties>

    <!--指定特定數據庫的jdbc驅動jar包的位置 -->
    <classPathEntry location="${jdbc.driverLocation}"/>

    <context id="default" targetRuntime="MyBatis3">

        <!--jdbc的數據庫鏈接 -->
        <jdbcConnection driverClass="${jdbc.driverClass}" connectionURL="${jdbc.connectionURL}" userId="${jdbc.userId}" password="${jdbc.password}">
        </jdbcConnection>


        <!--生成entity類存放位置-->
        <javaModelGenerator targetPackage="org.louis.hometutor.po" targetProject="src/main/java">
            <!-- 是否對model添加 構造函數 -->
            <property name="constructorBased" value="true"/>
            <!-- 是否對類CHAR類型的列的數據進行trim操做 -->
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>

        <!--生成映射文件存放位置-->
        <sqlMapGenerator targetPackage="org.louis.hometutor.domain" targetProject="src/main/java">
            <property name="enableSubPackages" value="false"/>
        </sqlMapGenerator>

        <!--生成Dao類存放位置-->
        <javaClientGenerator targetPackage="com.foo.tourist.dao" targetProject="src/main/java" type="MIXEDMAPPER">
            <property name="enableSubPackages" value="true"/>
        </javaClientGenerator>



        <table tableName="student" domainObjectName="Student">
            <generatedKey column="id" sqlStatement="select uuid_short()" identity="false"/>
            <!-- 用來修改表中某個列的屬性,MBG會使用修改後的列來生成domain的屬性;
               column:要從新設置的列名;
               注意,一個table元素中能夠有多個columnOverride元素哈~
             -->
            <columnOverride column="user_name">
                <!-- 使用property屬性來指定列要生成的屬性名稱 -->
                <property name="property" value="userName"/>
                <!-- javaType用於指定生成的domain的屬性類型,使用類型的全限定名-->
                <property name="javaType" value="java.lang.String"/>
                <!-- jdbcType用於指定該列的JDBC類型-->
                <property name="jdbcType" value="VARCHAR"/>
                <!-- 參考table元素的delimitAllColumns配置,默認爲false-->
                <property name="delimitedColumnName" value="true"/>
            </columnOverride>
        </table>

        <table tableName="teacher" domainObjectName="Teacher">
            <generatedKey column="id" sqlStatement="select uuid_short()" identity="false"/>
            <!-- 用來修改表中某個列的屬性,MBG會使用修改後的列來生成domain的屬性;
               column:要從新設置的列名;
               注意,一個table元素中能夠有多個columnOverride元素哈~
             -->
            <columnOverride column="user_name">
                <!-- 使用property屬性來指定列要生成的屬性名稱 -->
                <property name="property" value="userName"/>
                <!-- javaType用於指定生成的domain的屬性類型,使用類型的全限定名-->
                <property name="javaType" value="java.lang.String"/>
                <!-- jdbcType用於指定該列的JDBC類型-->
                <property name="jdbcType" value="VARCHAR"/>
                <!-- 參考table元素的delimitAllColumns配置,默認爲false-->
                <property name="delimitedColumnName" value="true"/>
            </columnOverride>
        </table>
    </context>
</generatorConfiguration>

這裏使用了外置的配置文件generator.properties,能夠將一下屬性配置到properties文件之中,增長配置的靈活性:css

jdbc.driverLocation=D:\\myfolder\\maven_repository\\mysql\\mysql-connector-java\\8.0.15\\mysql-connector-java-8.0.15.jar
jdbc.driverClass=com.mysql.cj.jdbc.Driver
jdbc.connectionURL=jdbc:mysql://localhost:3306/hxe_ant?useSSL=false&characterEncoding=UTF-8&serverTimezone=CTT&useAffectedRows=true&allowPublicKeyRetrieval=true
jdbc.userId=root
jdbc.password=root

  

項目目錄以下:html

技術分享

3. 在Intellij IDEA添加一個「Run運行」選項,使用maven運行mybatis-generator-maven-plugin插件 :

技術分享

技術分享

以後彈出運行配置框,爲當前配置配置一個名稱,這裏其名爲"generator",而後在 「Command line」 選項中輸入「mybatis-generator:generate  -e」java

這裏加了「-e 」選項是爲了讓該插件輸出詳細信息,這樣能夠幫助咱們定位問題mysql

技術分享

技術分享

若是添加成功,則會在run 選項中有「generator」 選項,以下:spring

技術分享

點擊運行,而後不出意外的話,會在控制檯輸出:sql

"C:\Program Files (x86)\Java\jdk1.8.0_73\bin\java.exe" -Dmaven.multiModuleProjectDirectory=D:\myfolder\code\ant-api -Dmaven.home=D:\myfolder\install\apache-maven-3.6.2 -Dclassworlds.conf=D:\myfolder\install\apache-maven-3.6.2\bin\m2.conf "-Dmaven.ext.class.path=D:\myfolder\install\IntelliJ IDEA 2019.2.3\plugins\maven\lib\maven-event-listener.jar" "-javaagent:D:\myfolder\install\IntelliJ IDEA 2019.2.3\lib\idea_rt.jar=58980:D:\myfolder\install\IntelliJ IDEA 2019.2.3\bin" -Dfile.encoding=UTF-8 -classpath D:\myfolder\install\apache-maven-3.6.2\boot\plexus-classworlds-2.6.0.jar org.codehaus.classworlds.Launcher -Didea.version2019.2.3 -s D:\myfolder\install\apache-maven-3.6.2\conf\settings.xml -Dmaven.repo.local=D:\myfolder\maven_repository mybatis-generator:generate -e
[INFO] Error stacktraces are turned on.
[INFO] Scanning for projects...
[WARNING] 
[WARNING] Some problems were encountered while building the effective model for com.huixiaoer:ant-api:jar:1.0.0-SNAPSHOT
[WARNING] 'dependencies.dependency.scope' for org.springframework.cloud:spring-cloud-dependencies:pom must be one of [provided, compile, runtime, test, system] but is 'import'. @ line 91, column 20
[WARNING] 'dependencies.dependency.scope' for org.springframework.boot:spring-boot-devtools:jar must be one of [provided, compile, runtime, test, system] but is 'true'. @ line 116, column 20
[WARNING] 
[WARNING] It is highly recommended to fix these problems because they threaten the stability of your build.
[WARNING] 
[WARNING] For this reason, future Maven versions might no longer support building such malformed projects.
[WARNING] 
[INFO] 
[INFO] -----------------------< com.huixiaoer:ant-api >------------------------
[INFO] Building ant-api 1.0.0-SNAPSHOT
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- mybatis-generator-maven-plugin:1.3.7:generate (default-cli) @ ant-api ---
[INFO] Connecting to the Database
[INFO] Introspecting table student
[INFO] Introspecting table teacher
[INFO] Generating Example class for table student
[INFO] Generating Record class for table student
[INFO] Generating Mapper Interface for table student
[INFO] Generating SQL Map for table student
[INFO] Generating Example class for table teacher
[INFO] Generating Record class for table teacher
[INFO] Generating Mapper Interface for table teacher
[INFO] Generating SQL Map for table teacher
[INFO] Saving file StudentMapper.xml
[INFO] Saving file TeacherMapper.xml
[INFO] Saving file StudentExample.java
[INFO] Saving file Student.java
[INFO] Saving file StudentMapper.java
[INFO] Saving file TeacherExample.java
[INFO] Saving file Teacher.java
[INFO] Saving file TeacherMapper.java
[WARNING] Cannot obtain primary key information from the database, generated objects may be incomplete
[WARNING] Cannot obtain primary key information from the database, generated objects may be incomplete
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  3.033 s
[INFO] Finished at: 2019-10-31T10:40:32+08:00
[INFO] ------------------------------------------------------------------------

看到BUILD SUCCESS,則大功告成,若是有錯誤的話,因爲添加了-e 選項,會把具體的詳細錯誤信息打印出來的,根據錯誤信息修改便可數據庫

 

原文地址:https://www.cnblogs.com/liaojie970/p/7058543.htmlapache

相關文章
相關標籤/搜索