一:什么是逆行工程。
MyBatis是一款优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
当数据库表比较多的时候,重复的创建pojo对象和简单的数据库表的(CRUD)操作的mapper,效率低,官方给出了使用mybatis Generator用来根据数据库表逆向生成pojo和mapper文件,极大的方便开发。
二:如何实现。
可以先去百度上搜索mybatis的官方文档以及提供的逆向工程文档。
https://mybatis.org/mybatis-3/
翻译过来就是:
- 从带有XML配置的命令提示符
- 作为具有XML配置的Ant任务
- 作为一个Maven插件
- 从另一个java程序,基于XML配置
- 从另一个java程序,基于java的配置
- 通过Eclipse插件
一般来说,我们会选择使用一个Java程序,基于XML配置来生成代码,下面来介绍具体操作。
数据表:
我这里创建了两个表,一个职工表,一个部门表,一个职工属于一个部门。
工程结构:
首先要在项目下建立一个配置的xml文件,这里为mbg.xml
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="root">
</jdbcConnection>
<javaTypeResolver>
<property name="forceBigDecimals" value="false" />
</javaTypeResolver>
<!-- 指定javaBean生成的位置 -->
<javaModelGenerator targetPackage="com.cc.crud.bean"
targetProject=".\src\main\java">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!--指定sql映射文件生成的位置 -->
<sqlMapGenerator targetPackage="mapper" targetProject=".\src\main\resources">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator>
<!-- 指定dao接口生成的位置,mapper接口 -->
<javaClientGenerator type="XMLMAPPER"
targetPackage="com.cc.crud.dao" targetProject=".\src\main\java">
<property name="enableSubPackages" value="true" />
</javaClientGenerator>
<!-- table指定每个表的生成策略 -->
<table tableName="tal_emp" domainObjectName="Employee"></table>
<table tableName="tal_dept" domainObjectName="Department"></table>
</context>
</generatorConfiguration>
注意:
- 配置数据库连接
- 指定javabean生成的位置
- 指定sql映射文件生成的位置
- 指定dao接口生成的位置,mapper接口
- table指定每个表的生成策略
下面再建议一个测试类:
MBGTest类
package com.cc.crud.test;
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;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
public class MBGTest {
public static void main(String[] args) throws Exception {
List<String> warnings = new ArrayList<String>();
boolean overwrite = true;
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);
}
}
注意:File文件的位置,要根据上述中的mbg.xml的位置来。
接下来运行MGBTest类即可,刷新项目,即可看到生成的文件。
如果原先生成过这样的文件,切记要把原来的删除掉再执行。
生成的代码:
这里生成的sql语句,根据字面意思就可理解。注意这只是单表的CRUD.如果要关联别的表,可自己在xml文件中跟据已生成的自行改。