1、添加依赖
<?xml version="1.0" encoding="UTF-8"?>
<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/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.ygz.generator</groupId>
<artifactId>MyBatisGeneratorTest</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.6</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.mybatis.generator/mybatis-generator-core -->
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.7</version>
</dependency>
<!--如果使用的其他数据库,改成相对应的依赖即可-->
<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
</dependencies>
</project>
2、配置generator.xml
在resources目录下新建generator.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>
<!-- 具体配置内容 -->
<context id="MybatisGenerator" targetRuntime="MyBatis3">
<!--是否压制(不产生)注释,没什么用,不产生就可以了,所以suppressAllComments设置为true-->
<commentGenerator>
<property name="suppressAllComments" value="true"/>
</commentGenerator>
<!--数据库连接信息,记得修改成自己的哦。数据库名,username和Password-->
<jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/stumanager" userId="test" password="123"></jdbcConnection>
<javaTypeResolver>
<!--是针对decimal和numeric这2个定点数类型,是否进行类型转换成BigDDecimals-->
<property name="forceBigDecimals" value="false"/>
</javaTypeResolver>
<!--实体类配置-->
<javaModelGenerator targetPackage="org.ygz.stumanager.models" targetProject="src">
<!--去空格-->
<property name="trimString" value="true"/>
<!--是否根据catalog和schema来生成子包-->
<property name="enableSubPackages" value="true"/>
</javaModelGenerator>
<!--Mapper配置-->
<sqlMapGenerator targetPackage="org.ygz.stumanager.mappers" targetProject="src">
<property name="enableSubPackages" value="true"/>
</sqlMapGenerator>
<!--接口配置-->
<javaClientGenerator type="XMLMAPPER" targetPackage="org.ygz.stumanager.mappers" targetProject="src">
<property name="enableSubPackages" value="true"/>
</javaClientGenerator>
<!--根据那几个表生成哪些相对应的Mapper和实体类,这里只测试两个表就好了-->
<table tableName="user"></table>
<table tableName="admin"></table>
</context>
</generatorConfiguration>
enableSubPackages属性的作用是:如果true,MBG会根据catalog和schema来生成子包。如果false就会直接用targetPackage属性。默认为false。
MBG:MyBatisGenerator的缩写
catalog:是由一个数据库实例的元数据组成的,包括基本表,同义词,索引,用户等等。
scheme:是对一个数据库的结构描述。在一个关系型数据库里面,schema定义了表、每个表的字段,还有表和字段之间的关系。
3、运行配置文件。