本文只是對於mybatis generator maven插件使用的個人記錄,作個備忘,同時也希望對進來的人有所幫助!
一.pom文件中引入插件
此處我引用的是1.3.5版本的,主要是1.3.4 版本及以上可以設置Mapper(Dao)後綴 如mapperName="LotteryDao"
<plugin>
<!--
用maven mybatis插件
如果不在plugin裏面添加依賴包得引用的話,會找不到相關得jar包,
在plugin外部得jar包,他不會去找到並執行,
所以要把plugin運行依賴得jar配置都放在裏面
-->
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.5</version>
<executions>
<execution>
<id>Generate MyBatis Artifacts</id>
<goals>
<goal>generate</goal>
</goals>
</execution>
</executions>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<!-- 引用依賴庫的版本 -->
<version>5.1.38</version>
</dependency>
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.5</version>
</dependency>
</dependencies>
</plugin>
注意,如果發現報錯Plugin execution not covered by lifecycle configuration: 需要在plugins的外層加上pluginManagement標籤.
二.添加generatorConfig.xml文件
在項目中添加Source File 目錄src/main/resources,裏面新建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="jdbc.properties"/>
<!-- 一個數據庫一個context -->
<context id="infoGuardian">
<!-- 註釋 -->
<commentGenerator >
<property name="suppressAllComments" value="true"/><!-- 是否取消註釋 -->
<property name="suppressDate" value="true" /> <!-- 是否生成註釋代時間戳-->
</commentGenerator>
<!-- jdbc連接 -->
<jdbcConnection driverClass="${jdbc_driverClassName}"
connectionURL="${jdbc_url}" userId="${jdbc_username}"
password="${jdbc_password}" />
<!-- 類型轉換 -->
<javaTypeResolver>
<!-- 是否使用bigDecimal, false可自動轉化以下類型(Long, Integer, Short, etc.) -->
<property name="forceBigDecimals" value="false"/>
</javaTypeResolver>
<!-- 生成實體類地址 -->
<javaModelGenerator targetPackage="com.tangdi.production.convenience.domain"
targetProject="src/main/java" >
<!-- 是否在當前路徑下新加一層schema,eg:fase路徑com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] -->
<property name="enableSubPackages" value="false"/>
<!-- 是否針對string類型的字段在set的時候進行trim調用 -->
<property name="trimStrings" value="true"/>
</javaModelGenerator>
<!-- 生成mapxml文件 -->
<sqlMapGenerator targetPackage="convenience-mapper"
targetProject="src/main/resources" >
<!-- 是否在當前路徑下新加一層schema,eg:fase路徑com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] -->
<property name="enableSubPackages" value="false" />
</sqlMapGenerator>
<!-- 生成mapxml對應client,也就是接口dao -->
<javaClientGenerator targetPackage="com.tangdi.production.convenience.dao"
targetProject="src/main/java" type="XMLMAPPER" >
<!-- 是否在當前路徑下新加一層schema,eg:fase路徑com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] -->
<property name="enableSubPackages" value="false" />
</javaClientGenerator>
<!-- 配置表信息
1.3.4 版本及以上可以設置Mapper(Dao)後綴 如mapperName="LotteryDao"
tableName爲對應的數據庫表 domainObjectName是要生成的實體類名 enable*ByExample 是否生成 example類
-->
<table tableName="convenience_lotteryuser_inf" domainObjectName="LotteryInf" mapperName="LotteryDao"
enableCountByExample="false" enableDeleteByExample="false" enableSelectByExample="false"
enableUpdateByExample="false">
<!-- 忽略列,不生成bean 字段 -->
<!-- <ignoreColumn column="FRED" /> -->
<!-- 指定列的java數據類型 -->
<!-- <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> -->
</table>
</context>
</generatorConfiguration>
jdbc_driverClassName=com.mysql.jdbc.Driver
jdbc_url=jdbc:mysql://127.0.0.1:3306/dev
jdbc_username=dev
jdbc_password=*******
三.右鍵pom文件,Run As 用maven build --> Goals中輸入 mybatis-generator:generate運行即可
四.mybatis generator gui界面工具 推薦使用
另外,有網友基於mybatis generator開發了一款界面工具, 本工具可以使你非常容易及快速生成Mybatis的Java POJO文件及數據庫Mapping文件。
地址:https://github.com/astarring/mybatis-generator-gui
經試用,也是非常好用! 一般第一次設置過之後,後面雙擊表名即可!