在pom中增加對mybatis generator插件的支持,我這裏將xml配置文件放到了test目錄裏面,實際打包時可以不打這個目錄
<build>
<plugins>
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.5</version>
<configuration>
<!--允許移動生成的文件 -->
<verbose>false</verbose>
<!-- 是否覆蓋 -->
<overwrite>true</overwrite>
<!-- 自動生成的配置 -->
<configurationFile>
${project.basedir}/src/test/resources/generator/generatorConfig.xml
</configurationFile>
</configuration>
</plugin>
</plugins>
</build>
配置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>
<!-- 指定外部數據連接驅動jar地址 -->
<classPathEntry location="/Users/system/workspace/aa/gtr/lib/mysql-connector-java-6.0.6.jar"/>
<!-- 一個數據庫一個context -->
<context id="yb-op-notice-orm" targetRuntime="MyBatis3">
<!-- 修改生成的查詢對象後綴 -->
<plugin type="org.mybatis.generator.plugins.RenameExampleClassPlugin">
<property name="searchString" value="Example$"/>
<property name="replaceString" value="Query"/>
</plugin>
<!-- 註釋 -->
<commentGenerator>
<property name="suppressAllComments" value="true"/><!-- 是否取消生成代碼後的註釋 -->
<property name="suppressDate" value="true"/> <!-- 是否生成註釋時間戳-->
</commentGenerator>
<!-- jdbc連接 -->
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://192.168.137.8:3358/gtr?serverTimezone=UTC&characterEncoding=utf8&useUnicode=true&useSSL=false"
userId="root"
password="123456"/>
<!-- 類型轉換 -->
<javaTypeResolver>
<!-- 是否使用bigDecimal, false可自動轉化以下類型(Long, Integer, Short, etc.) -->
<property name="forceBigDecimals" value="false"/>
</javaTypeResolver>
<!--<!– 生成實體類地址 –>-->
<javaModelGenerator targetPackage="com.zq.gtr.dal.entity"
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="com.zq.gtr.dal.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
type="ANNOTATEDMAPPER",生成Java Model 和基於註解的Mapper對象
type="MIXEDMAPPER",生成基於註解的Java Model 和相應的Mapper對象
type="XMLMAPPER",生成SQLMap XML文件和獨立的Mapper接口
-->
<javaClientGenerator targetPackage="com.zq.gtr.dal.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>
<!-- 配置表信息 -->
<!-- schema即爲數據庫名 tableName爲對應的數據庫表 domainObjectName是要生成的實體類 enable*ByExample
是否生成 example類 -->
<!-- 忽略列,不生成bean 字段 -->
<!--<ignoreColumn column="FRED"/>-->
<!-- 指定列的java數據類型 -->
<!--<columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR"/>-->
<table schema="gtr"
tableName="activity_info"
domainObjectName="ActivityInfo"
enableCountByExample="true"
enableUpdateByExample="true"
enableDeleteByExample="true"
enableSelectByExample="true"
selectByExampleQueryId="true">
<generatedKey column="id" sqlStatement="Mysql" identity="true"/>
<columnOverride column="yn" javaType="java.lang.Integer"/>
</table>
</context>
</generatorConfiguration>