mybatis逆向工程(MyBatis Generator)
2024-10-18 18:16:50
mybatis逆向工程(MyBatis Generator)
1. 什么是mybatis逆向工程
mybatis官方为了提高开发效率,提高自动对单表生成sql,包括 :mapper.xml、mapper.java、表名.java(po类)
在企业开发中通常是在设计阶段对表进行设计 、创建。
在开发阶段根据表结构创建对应的po类。
mybatis逆向工程的方向:由数据库表----》java代码
2. 逆向工程创建(方式一)
2.1 逆向工程使用配置
本实例使用通过java程序运行逆向工程;
逆向工程运行所需要的jar包:
2.2. 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>
<!-- 1、连接数据库的驱动包路径 -->
<classPathEntry location="D:\WorkspaceJ2eeMyeclipse\generator\WebRoot\WEB-INF\lib\mysql-connector-java-5.1.44-bin.jar" /> <context id="DB2Tables" targetRuntime="MyBatis3">
<!-- 1、连接数据库的地址和驱动:数据库链接URL、用户名、密码 -->
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/elec"
userId="root"
password="123456">
</jdbcConnection> <javaTypeResolver >
<property name="forceBigDecimals" value="false" />
</javaTypeResolver> <!-- 生成模型的包名和位置 -->
<javaModelGenerator targetPackage="com.mmzs.pojo" targetProject="generator">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator> <!-- 生成的映射文件包名和位置 -->
<sqlMapGenerator targetPackage="com.mmzs.mapper" targetProject="generator">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator> <!-- 生成DAO的包名和位置 -->
<javaClientGenerator type="XMLMAPPER" targetPackage="com.mmzs.mapper" targetProject="generator">
<property name="enableSubPackages" value="true" />
</javaClientGenerator> <!-- 要生成那些表(更改tableName和domainObjectName就可以) -->
<table tableName="testkeycount" domainObjectName="KeyCountbean"
enableCountByExample="false" enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false"
selectByExampleQueryId="false">
</table> <table tableName="testnum" domainObjectName="Numbean"
enableCountByExample="false" enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false"
selectByExampleQueryId="false">
</table>
<!-- <table tableName="t_student" domainObjectName="StuBean"/> --> </context>
</generatorConfiguration>
generator.xml
目前工程结构如下:
2.3 运行
然后右击generator.xml文件===>>单击"Generator MyBatis/iBATIS Artifacts"按钮,此时就自动生成成功了;
效果如下:
代码已上传,或者加右侧java的QQ群下载
3. 逆向工程创建(方式二)
3.1 逆向工程使用配置
本实例使用通过java程序运行逆向工程;
逆向工程运行所需要的jar包:
3.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>
<context id="testTables" targetRuntime="MyBatis3">
<commentGenerator>
<!-- 是否去除自动生成的注释 true:是 : false:否 -->
<property name="suppressAllComments" value="false" />
</commentGenerator> <!--数据库连接的信息:驱动类、连接地址、用户名、密码 -->
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/elec"
userId="root"
password="123456">
</jdbcConnection> <!-- 默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true时把JDBC DECIMAL 和
NUMERIC 类型解析为java.math.BigDecimal -->
<javaTypeResolver>
<property name="forceBigDecimals" value="false" />
</javaTypeResolver> <!-- targetProject:生成PO类的位置 -->
<javaModelGenerator targetPackage="com.mmzs.pojo"
targetProject=".\src">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false" />
<!-- 从数据库返回的值被清理前后的空格 -->
<property name="trimStrings" value="true" />
</javaModelGenerator> <!-- targetProject:mapper映射文件生成的位置 -->
<sqlMapGenerator targetPackage="com.mmzs.mapper"
targetProject=".\src">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false" />
</sqlMapGenerator> <!-- targetPackage:mapper接口生成的位置 -->
<javaClientGenerator type="XMLMAPPER"
targetPackage="com.mmzs.mapper"
targetProject=".\src">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false" />
</javaClientGenerator> <!-- 指定数据库表 -->
<table schema="" tableName="testnum"></table>
<table schema="" tableName="testkeycount"></table>
<table schema="" tableName="user"></table> </context>
</generatorConfiguration>
generatorConfig.xml
3.3 配置需要执行的java程序
package com.mmzs.generator; import java.io.File;
import java.io.IOException;
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.exception.XMLParserException;
import org.mybatis.generator.internal.DefaultShellCallback; public class Generator { public static void main(String[] args) throws Exception {
try {
Generator generatorSqlmap = new Generator();
generatorSqlmap.generator();
System.out.println("逆向工程自动创建完成");
} catch (Exception e) {
e.printStackTrace();
}
} //调用generatorConfig.xml文件,根据其配置自动生成
public void generator() throws Exception{
List<String> warnings = new ArrayList<String>();
boolean overwrite = true;
//指定 逆向工程配置文件
File configFile = new File("generatorConfig.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);
} }
Generator.java
3.4 运行
执行Generator.java程序后,所生成的代码已经生成到当前工程中;
效果如下:(显示可能有延迟,需要刷新工程才能看到生成的结果)
代码已上传,或者加右侧java的QQ群下载
相关链接:玩转SpringBoot之MyBatisplus自动化构建工具
最新文章
- angular模块和组件之间传递信息和操作流程的方法(笔记)
- 在浏览器中输入Google.com并且按下回车之后发生了什么(转载)
- python学习三
- 【BZOJ】【3530】【SDOI2014】数数
- Eclipse 环境安装和配置优化
- iframe 刷新
- 学习面试题Day04
- 打造强大的BaseModel(1):让Model自我描述
- JavaWeb核心编程之(三.4)Servlet Context 配置
- 从UIImage的矩阵变换看矩阵运算的原理
- HttpServletRequest和ServletRequest的区别
- ZOJ2006 一道很尴尬的string操作题
- asp.net+jQueryRotate开发幸运大转盘
- 把python学的让自己成为智障的day14
- springcloud干货之服务注册与发现(Eureka)
- 爆料:2019手游折扣app是真福利还是骗人哪个靠谱?
- PHP之错误
- Android 关于导航栏(虚拟按键)遮挡PopupWindow底部布局的问题
- 缓存服务,还未创建完缓存时, 需要更改图层名称、服务名称、数据源位置、mxd名称等
- oracle 分组取第一行数据 ,查询sql语句
热门文章
- 洛谷P1596 [USACO10OCT]湖计数Lake Counting
- 与我们息息相关的internet服务(3)---电子邮件服务
- EasyUI 学习(1)-Tooltip(提示框)
- [转] 如何用kaldi训练好的模型做特定任务的在线识别
- JVM之虚拟机类加载机制
- 通过代码定义shape/selector
- spring中的mybatis的sqlSession是如何做到线程隔离的?
- Rpc框架dubbo-server(v2.6.3) 源码阅读(一)
- 用Ajax遍历三级下拉框
- idea 过段时间java程序包不存在问题 ?