1.首先在项目的pom文件中加入如下的代码片段,进行插件配置
<build>
<plugins>
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.5</version>
<configuration>
<!--项目中mybatis-generator.xml配置文件的位置,一定要保证正确-->
<configurationFile>src\main\resources\mybatis-generator\generatorConfig.xml</configurationFile>
<verbose>true</verbose>
<overwrite>true</overwrite>
</configuration>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql-connector}</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>
2.第二部分配置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="mybatis-generator/generator.properties"/>
<context id="my" targetRuntime="MyBatis3" defaultModelType="flat">
<!--自动实现Serializable接口-->
<plugin type="org.mybatis.generator.plugins.SerializablePlugin"></plugin>
<!-- 去除自动生成的注释 -->
<commentGenerator>
<property name="suppressAllComments" value="false" />
</commentGenerator>
<!--数据库基本信息-->
<jdbcConnection driverClass="${jdbc.driverClass}"
connectionURL="${jdbc.connectionURL}"
userId="${jdbc.user}"
password="${jdbc.password}">
</jdbcConnection>
<!--生成实体类的位置以及包的名字-->
<javaModelGenerator targetPackage="${model.TargetPackage}" targetProject="${model.TargetProject}">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="true" />
<!-- 从数据库返回的值被清理前后的空格 -->
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!--生成映射文件存放位置-->
<sqlMapGenerator targetPackage="${mapper.XMLTargetPackage}" targetProject="${mapper.XmlTargetProject}">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false"/>
</sqlMapGenerator>
<!--生成Dao类存放位置,mapper接口生成的位置-->
<javaClientGenerator type="XMLMAPPER" targetPackage="${dao.TargetPackage}" targetProject="${dao.TargetProject}">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false"/>
</javaClientGenerator>
<!-- 配置表信息 -->
<!-- schema即为数据库名 tableName为对应的数据库表 domainObjectName是要生成的实体类 enable*ByExample
是否生成 example类 -->
<table schema="${dbName}" tableName="${tableName}"
domainObjectName="${domainObjectName}" enableCountByExample="false"
enableDeleteByExample="false" enableSelectByExample="false"
enableUpdateByExample="false">
</table>
</context>
</generatorConfiguration>
3.其中xml文件中的可以引用配置文件,这里我们引用配置文件generator.properties
#数据库连接信息
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.connectionURL=###
jdbc.user=###
jdbc.password=###
#实体类位置
model.TargetPackage=###
model.TargetProject=src/main/java
#mapper.xml文件位置
mapper.XMLTargetPackage=mapper
mapper.XmlTargetProject=src/main/resources
#dao文件位置
dao.TargetPackage=###
dao.TargetProject=src/main/java
#数据库名
dbName=###
#需要生产的表名
tableName=###
#指定生成实体类名
domainObjectName=###
配置完之后在项目中就可以运用maven插件生成map.xml,实体类,dao类,可以很大的提高开发效率。