mybatis-generator-gui-extension是一个为MybatisGenerator编写的图形化界面,为实体
/Example
/Mapper
提供了丰富的扩展。
文件合并
:在重新生成代码时,将保留没有添加@mbg.generated
注释的字段/方法/SQL语句- 可合并的文件:
实体类
、Example
、Mapper.java
、Mapper.xml
- 可合并的文件:
自动包裹关键字
:对于表名/字段名为关键字的情况,可指定用 ` 或其他字符串包裹,防止冲突实体类增强
rootClass
(可选):可为实体对象指定RootClasstrim
(可选):为String类型的setter添加trim
使用真实列名
(可选):可指定是否使用真实列名流式构建
(可选):直接使用User user= new User().withUsername("uname").withPassword("123");
创建对象toString
(可选):生成toString方法(可选择是否调用父类的toString
方法)equals/hashCode
(可选):生成equals/hashCode
方法(可选择是否调用父类的equals/hashCode 方法)Serializable
(可选):继承Serializable
接口
Example增强
CaseInsensitiveLike
:添加CaseInsensitiveLike查询方式ExampleCriteria增强插件
真实字段获取插件
分页插件
:提供基于limit/offset的分页。
Mapper增强
指定Mapper类型
:可选择纯xml
/java和xml混合
/纯java
的方式生成mapper指定主键
:可指定表的主键,将会自动为该表生成获取自增主键的SQL虚拟主键
:逻辑删除
批量插入
添加@Mapper注解
各个方法的开关
生成JPA注解
指定类头注释
:自定义生成的文件的注释缓存
:采用MBG官方的缓存插件,为生成的查询方法提供cache标签- 指定BasPackage
对象重命名
:Example
类的重命名实体
类的重命名Mapper
类的重命名
指定后缀
: 可修改如下项目的后缀:dao包
、实体包
、Mapper
、Example
、实体
。
运行前请确保您的JDK版本为1.8u40以上
前三种方式需要先下载源代码
源码运行
: 用IDE将源代码导入为Maven项目,然后直接运行com.spawpaw.mybatis.generator.gui.GeneratorGuiRunner
即可
自助打包jar
: 执行 mvn package
自助打包exe
: 执行 mvn package jfx:native
直接下载jar包
: 选择版本进行下载
二次开发 && 交流 (进入帮助页面)
- 如果您开发了自己的MBG插件,只需几行代码便可将其暴露到图形界面中,无需了解整个项目的构造。(参见四步将Plugin的配置暴露到图形化界面中)
如果您在使用过程中遇到了BUG,或者想让软件添加某些功能,请挂issue或者联系作者:[email protected]
项目地址 https://github.com/spawpaw/mybatis-generator-gui-extension
QQ交流群:171209016
在本项目的issue页,创建一个issue,描述你所要添加的功能。
将本仓库fork到你自己的账户,并将你的代码提交。
提交完成后,你将会在你的仓库中看到PullRequest
按钮,点击发起PR然后按照提示操作就可以了。
tips: 在commit时可以使用#<issue-id>
来关联issue
如果您觉得本软件对您有帮助,请别忘记给这个项目一个star
ο(=•ω<=)ρ⌒★
先来看一下您的项目是否有如下需求:
- 需要根据表结构生成其他代码:比如service、controller甚至是前端的代码。
- 要求对SQL高度可控:DBA需要审查SQL脚本或需要使用自动化工具对所有SQL脚本进行检查。
如果有上面任意一项需求,那么使用本工具是没有任何问题的。 但是如果你追求快速的开发,简洁的代码,建议使用Spring Data JPA、mybatis-plus 、 通用Mapper, 这些项目提供了更优雅的方式来实现简单的CRUD、Example查询,毕竟大部分项目在大部分情况下很少遇到手写复杂代码的情况,会触及性能问题的代码也很少(即使有也很容易定位),通过本工具生成的大量代码反而可能会给维护带来一定麻烦。