在使用Mybatis框架的JavaWeb项目中通过Mybatis Generator逆向工程自动生成Java类文件
在使用Mybatis框架的JavaWeb应用中通常要在src中创建实体类包(bean)、持久层的sql语句映射类包(mapper)、接口类包(dao)这些类包文件,当项目规模变大数据表单变多时,通过手动创建这些类包就会相当繁琐,所以这是可以通过使用mybatis generator来逆向自动生成这些类包文件。
目录
引入Mybatis Generator
如果你使用的是maven工程,那么在maven的配置文件pom.xml中加入如下代码:
<!-- mybatis generator 逆向工程代码生成器 -->
<!-- https://mvnrepository.com/artifact/org.mybatis.generator/mybatis-generator-core -->
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.5</version>
</dependency>
如果使用的是java web项目,那么先下载mybatis generator的jar包,下载地址如下:
https://github.com/mybatis/generator/releases
将下载到的jar文件放到项目的lib目录中。
配置Mybatis Generator逆向生成的相关参数
在项目的任意目录创建mbg.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="DB2Tables" targetRuntime="MyBatis3">
<!-- 设置生成的文件中没有注释 -->
<commentGenerator>
<property name="suppressAllComments" value="true" />
</commentGenerator>
<!-- 配置数据库连接信息 -->
<!-- 这里根据自己的数据库信息进行配置 -->
<jdbcConnection
driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/ssm_crud"
userId="root"
password="">
</jdbcConnection>
<javaTypeResolver >
<property name="forceBigDecimals" value="false" />
</javaTypeResolver>
<!-- 指定javabean生成的位置 -->
<javaModelGenerator targetPackage="com.crud.bean" targetProject=".\src\main\java">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!-- 指定sql映射文件生成的位置 -->
<sqlMapGenerator targetPackage="com.crud.mapper" targetProject=".\src\main\java">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator>
<!-- 指定dao接口生成的位置 mapper接口 -->
<javaClientGenerator type="XMLMAPPER" targetPackage="com.atguigu.crud.dao" targetProject=".\src\main\java">
<property name="enableSubPackages" value="true" />
</javaClientGenerator>
<!-- 指定每个表的生成策略 -->
<!--
tableName:表名
domainObjectName:对应的表单类的类名
-->
<table tableName="tbl_employee" domainObjectName="Employee" >
</table>
<table tableName="tbl_dept" domainObjectName="Department">
</table>
</context>
</generatorConfiguration>
编写生成方法并执行
在任意目录创建一个class文件,这里我命名为MGBTest.java,内容如下:
package com.crud.test;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
import org.mybatis.generator.api.MyBatisGenerator;
import org.mybatis.generator.config.Configuration;
import org.mybatis.generator.config.xml.ConfigurationParser;
import org.mybatis.generator.internal.DefaultShellCallback;
public class MGBTest {
public static void main(String[] args) throws Exception {
List<String> warnings = new ArrayList<String>();
boolean overwrite = true;
//这里根据之前创建mbg.xml的目录进行配置
File configFile = new File("mbg.xml");
ConfigurationParser cp = new ConfigurationParser(warnings);
Configuration config = cp.parseConfiguration(configFile);
DefaultShellCallback callback = new DefaultShellCallback(overwrite);
MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
myBatisGenerator.generate(null);
}
}
直接运行该方法,然后刷新项目文件即可看到相应的java类文件被创建出来了。