基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

v4.1.2版更新震撼发布,功能更加强大,速度过来围观,此次版本更新如下:

1、随着程序的功能越来越强大,原来的定位和设计已经无法满足更高的要求,所以决定对本程序更名,更名为TableGo,以满足未来更丰富的功能和设计。
2、新增快速生成数据库设计文档和批量生成数据库设计文档的功能。
3、新增根据字段快速生成JavaBean的功能,在VO中增量添加字段非常方便。
4、新增精确匹配(排除)和模糊匹配(排除),排除掉不需要生成的表。
5、新增数据源备注,该备注用于自动生成数据库设计文档的文件名。
6、新增多线程超时参数设置,在生成文档时因表字段太多而超时时可修改。
7、修改了界面布局,使布局更加合理。
8、修改实体注解使其能自动选中已选择的注解。
9、优化表命名转驼峰命名和驼峰命名转表命名,使其支持单词间的空格,使用起来更方便。
10、其他一些小Bug的修改和代码优化调整。

欢迎访问TableGo官网:
http://www.tablego.cn

这里还有个设置的技巧,就是在设置实体生成策略时最好选择无字段验证的,因为我发现通过JDBC获取字段验证数据时会有点慢,效率不高。而且通过配置Hibernate和MyBaits的命名策略完全可以把实体生成策略设置成”所有字段上均无Column注解”,这样生成JavaBean速度最快,而且以后代码维护也方便很多。

Hibernate或JPA配置:hibernate.ejb.naming_strategy=org.hibernate.cfg.ImprovedNamingStrategy

MySQL配置:mapUnderscoreToCamelCase=true (这样配置以后在mapper.xml中就不需要写resultMap了)

MySQL使用的数据库驱动包:mysql-connector-java-5.1.39.jar

Oracle使用的数据库驱动包:ojdbc14.jar

SQL Server使用的数据库驱动包:sqljdbc4.jar

PostgreSQL使用的数据库驱动包:postgresql-9.4.1208.jre7.jar

一直以来把数据库的表转换成JavaBean和数据库设计文档都是一件让人很头痛的事情,既浪费时间又很繁琐,看着几十上百个表的成千上万个字段,真是一件让人痛苦的事情。

我们也想过很多办法解决这个问题,包括用MyEclipse连接数据库生成JavaBean,但多多少少还是会有一些不尽人意的地方,包括表和表字段的comment总是无法生成,而且还会生成很多无用的注释代码,让代码看起来一点都不干净,配置非常繁琐等等问题。

于是一怒之下,自己动手丰衣足食,于是就自己用Swing写了一个基于数据库的自动化生成工具,支持MySQL、Oracle、SQLServce、PostgreSQL,完美支持JPA注解,可以同时生成Entity和DTO等,可以自动去除表前缀,支持单个和批量生成JavaBean,现在不但成员变量上能生成备注了,而且在Getter和Setter上也能有注释了。更重要的是还能自动生成数据库设计文档,如果有多个数据源还能批量生成,使用非常方便。

所有的配置都保存在本地,只要配置过一次,下次使用的时候完全可以秒生成JavaBean和数据库设计文档,并且还集成各种实用工具,使得工作效率瞬间爆棚,生产力瞬间爆表!

经过一些项目的使用和积累,我把它分享出来,大家有什么好的建议和想法也都可以提出来,因为比较忙,没有时间去做非常全面的测试,所以一定会有些bug。由于环境的原因,主要测试的是MySQL、Oracle,SQLServer、PostgreSQL测试不全,可能会有点Bug,大家如果发现什么Bug记得要告诉我,在下个版本中进行修正。

1、配置数据源界面:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

2、配置转换参数界面:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

3、字段设置界面,可以根据需求的不同设置字段转换类型,并可以在Date类型上添加注解配置:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

4、高级设置界面:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

5、集成工具界面,集成一些实用工具,工作效率瞬间提升数倍:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

6、换肤功能,38款皮肤任你选,总有一款适合你:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

7、数据源配置管理功能,可以为每种类型的数据库添加多个不同的数据源。删除需勾选要删除的数据源,修改和选择数据源无需勾选,双击可快速选中需要的数据源:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

8、快速新增数据源功能,快速为当前选中的数据库添加数据源,备注用于自动生成数据库文档名:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

9、参数配置管理功能,可以为不同的项目配置不同的参数:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

10、快速新增参数配置功能,快速为项目添加参数配置:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

11、打开目录功能,左键打开菜单选择要打开的目录,点击右键可以快速打开当前应用所在目录:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

12、选择支持的数据库后,下面的数据源、IP地址、库名、端口、用户名、密码、备注和数据库文档名都会自动跟着做相应的变化,以支持不同的数据源配置:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

13、配置好数据库以后点击测试数据库连接按钮就能测试数据库是否能够连接成功并显示数据库版本信息:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

14、新增快速生成数据库文档的功能,支持同时生成Bean和数据库设计文档,如果在生成文档时出现多线程处理超时异常,可通过增加多线程超时时间和减少每个线程处理的表数量来避免超时异常(修改多线程参数需重启程序):

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

15、选择模板的功能,可以根据需要生成不同语言的Bean。大家如果想要生成其它编程语言的Bean可以发一个那种编程语言的标准Bean给我,我做成标准模板发布上来:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

16、查看数据库中所有表的对话框,在精确匹配文本框旁点击更多按钮,即可弹出选择数据库表的对话框,这里将列出数据库中所有的表,并支持模糊查询(不区分大小写)查找需要的表,在复选框中选中需要的表,点确认选择即可(双击可快速选中):

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

17、生成实体时要使用的schema,schema可以自动生成:如果schema与数据库的用户名相同则选dbUsername,如果schema与数据库的库名相同则选dbName

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

18、可以同时生成Entity和DTO,也可以选择只生成某种类型的Bean:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

19、支持带JPA注解和不带JPA注解的Bean:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

20、选择实体注解功能,生成实体的时候自动为实体添加额外的注解,可自动为非空字段添加@NotBlank或@NotNull验证注解:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

21、实体生成策略,可以根据需求为实体配置不同的生成策略:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

22、实体主键生成策略,可以配置手动生成主键也可以配置自动生成主键:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

23、自定义设置文件注释和设置类注释的功能,并可以使用部分内部参数:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

24、新增根据字段生成JavaBean功能,在VO中增量添加字段非常方便:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

25、新增批量生成数据库设计文档功能,可快速批量的生成数据库设计文档,如果在生成文档时出现多线程处理超时异常,可通过增加多线程超时时间和减少每个线程处理的表数量来避免超时异常(修改多线程参数需重启程序):

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

这是我在真实的大项目中批量生成的数据库设计文档:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

26、String字符串拼接工具,实现秒拼StringBuffer,再也不怕拼长长的SQL了:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

27、清除StringBuffer工具,是String字符串拼接工具的逆向工具:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

28、字符串格式化工具,提高工作效率的利器:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

29、表命名转驼峰命名工具:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

30、驼峰命名转表命名工具:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

31、JSON字符串格式化工具:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

32、XML字符串格式化工具:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

33、JSON To XML工具:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

34、XML To JSON工具:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

35、程序第一次打开会自动生成两个配置文件,一个是配置数据库的,一个是配置参数的,如果设置了文件注释和类注释还会生成这两个注释的配置文件,一般第一次进去只要配置好数据库,点生成JavaBean,默认就能同时生成Entity和DTO了:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

36、这是自动生成出来的Entity和DTO:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

37、这是最新的源代码统计,通过几个版的功能叠加,现在的代码量已经有上万行了:

基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

下载地址:http://download.csdn.net/detail/vipbooks/9732104

该压缩包中包含32位和64位两个版本。

使用该工具需要安装JDK7及以上版本的,因为现在用的开发环境和编译环境都是JDK7,其它版本的JDK还没有测试过,更高版本的应该没有问题,必需要在操作系统的环境变量里配置好JAVA_HOME,不然会找不到Java。

找了好多的把Jar包打包成EXE文件的工具,都不能完美支持64位的系统,最后找到了exe4j,终于能完美支持打包成64位系统支持的版本了,我自己用的是Alienware15R2自带的64位Win10系统,如果生成的32位程序不能运行大家就说一声,我再去找虚拟机测试。

这篇文章我也在ITeye发表了,这两个博客都是我自己的,该文章中提到的这个软件是我自己开发出来的。如果你由于缺少积而无法下载,可以在
http://vipbooks.iteye.com/blog/2351354

免费下载,如果你觉得这个软件不错,希望可以下载我上传到CSDN中的版本,只需要1点积分,也是对我的支持,谢谢!

目录:

第1版:
http://blog.csdn.net/vipbooks/article/details/51912143

第2版:
http://blog.csdn.net/vipbooks/article/details/51912537

第3版:
http://blog.csdn.net/vipbooks/article/details/51912750

第4版:
http://blog.csdn.net/vipbooks/article/details/51912930

第5版:
http://blog.csdn.net/vipbooks/article/details/51915364

第6版:
http://blog.csdn.net/vipbooks/article/details/51916266

第7版:
http://blog.csdn.net/vipbooks/article/details/51916507

第8版:
http://blog.csdn.net/vipbooks/article/details/52005477

第9版:
http://blog.csdn.net/vipbooks/article/details/52005926

第10版:
http://blog.csdn.net/vipbooks/article/details/52226266

第11版:
http://blog.csdn.net/vipbooks/article/details/52806475

第12版:
http://blog.csdn.net/vipbooks/article/details/53242808

v4.1.2版:
http://blog.csdn.net/vipbooks/article/details/54234432

v5.0.0版:
http://blog.csdn.net/vipbooks/article/details/72653898

v5.8.0版:
http://blog.csdn.net/vipbooks/article/details/78767469

v5.8.8版:
http://blog.csdn.net/vipbooks/article/details/79492051
;

v6.0.0版:
http://blog.csdn.net/vipbooks/article/details/90244554

Original: https://www.cnblogs.com/vipbooks/p/6275330.html
Author: vipbooks
Title: 基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/594253/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 在.NET中调用Java的类

    .NET不能直接调用Java的类,但IKVM.NET解决了这个问题。IKVM.NET提供了两种方式调用java的类:①把生成的jar包放置在程序根目录,然后通过创建URL实例的方式…

    Java 2023年5月29日
    067
  • webpack快速入门(二):使用入门

    继续之前请确认你已经安装了nodejs 安装、初始化: 然后找个目录新建名为webpack-demo的文件夹,然后在命令行下进入该目录,执行以下命令: 一个初始化命令,会在当前目录…

    Java 2023年6月16日
    066
  • 再也不担心构建问题了

    希望这篇文章可以理清这个工具,了解其使用。 前言 说真的,autotools工具让我很头疼,各种类似的工具 autolocal , automake 以及生产各种相似的文件 Mak…

    Java 2023年5月30日
    064
  • EasyExcel配置步骤

    1.介绍 EasyExcel是一个基于Java的简单、省内存的读写Excel的开源项目参考https://blog.csdn.net/u013044713/article/deta…

    Java 2023年6月9日
    061
  • 20220930-Vector集合扩容机制源码分析

    总结: ArrayList与Vector集合的底层都是通过Object[] elementData数组存放对象的 ArrayList使用无参构造器时,初始容量为0,当存放一个对象后…

    Java 2023年6月15日
    085
  • SpringBoot日志框架

    概述 项目中日志系统是必不可少的的。 目前比较流行的日志框架有 log4j、 logback等 。可能大家还不知道,这两个框架的作者是同一个人, Logback旨在作为流行的 lo…

    Java 2023年6月8日
    0111
  • 零点问题与微分不等式

    零点问题与微分不等式 零点问题关注于”有没有解”,”有几个解”。 单调性与存在性 罗尔原话 多项式方程的根 单调性与存在性 可以使用…

    Java 2023年6月7日
    059
  • 面向对象ooDay5

    默认的:什么也不写,本类、同包类 说明: java不建议默认访问权限 类的访问权限只能是public或默认的,类中成员的访问权限如上4种都可以 访问权限由小到大依次为:privat…

    Java 2023年6月13日
    072
  • Oracle数据库😊

    sqlplus常用命令 连接数据库:conn 用户名/密码@网络服务标识[as sysdba] 断开数据库连接: 断开和oracle的连接但是不退出sqlplus窗口 区别:sta…

    Java 2023年6月15日
    045
  • tortoisegit 配置ssh登录

    习惯使用小乌龟。 服务器:gitblit 客户端:TortoiseGit 2.13.0.1 (C:\Program Files\TortoiseGit\bin) git versi…

    Java 2023年6月9日
    0102
  • G1收集器

    G1之前垃圾收集器预习: https://www.cnblogs.com/fengtingxin/p/13966982.html GC统一语义: 部分收集(Partial GC) …

    Java 2023年6月8日
    069
  • 通用树形结构的迭代与组合模式实现方案

    日常开发过程过程中。树形结构运用的非常频繁。 例如:公司组织结构、各种分类结构、分组结构等等。 SET FOREIGN_KEY_CHECKS = 0; CREATE TABLE I…

    Java 2023年6月9日
    0109
  • idea中自定义修改jdk源码,加注释

    前言 最近打算出jdk源码的博客,想在源码基础上加注释,在此把方法分享给大家。 处理方法 打开project structures,选择sdk。根据上方的路径,找到zip包,进行解…

    Java 2023年5月30日
    094
  • 注解@PostConstruct分析

    1.注解@PostConstruct可以添加在类的方法上面,如果这个类被IOC容器托管,那么在对Bean进行初始化前的时候会调用被这个注解修饰的方法 被定义在哪里? 1.被定义在了…

    Java 2023年6月15日
    059
  • 译文《全新首发JDK 16全部新特性》

    封面:洛小汐 译者:潘潘 JDK 8 的新特性都还没摸透,JDK 16 的新特性就提着刀来了。 郑重申明:第一次冒险翻译专业领域的文献,可想而知,效果特别糟糕。一般翻译文献特别是 …

    Java 2023年6月13日
    046
  • springboot 80转443

    application.yml 中配置https证书信息 向spring容器中注入两个Bean,代码如下 import java.util.Map; import org.apac…

    Java 2023年5月30日
    086
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球