让myql中的数据库表自动生成javaBean的模板

本文介绍了一个将MySQL数据库表字段自动映射为JavaBean的工具,旨在提高编程效率,避免手动编写bean类。通过指定文件路径、名称、包名和是否使用Lombok,该工具能根据数据库表结构生成标准的JavaBean文件。
摘要由CSDN通过智能技术生成

不积跬步,无以至千里

问题所在

今天重构以前的代码,因为数据库有比较大的改动,所以需要写很多javaBean!

作为一个程序员,重复意味着没有效率,更意味着无聊,一旦无聊便没有想编程的欲望,代码质量肯定刷刷刷的下降,质量下降了就意味着重写。。。。

so,为了集中精力在业务逻辑的代码上,减少不必要的时间浪费,于是花了一点时间写了一个把数据库中表的字段自动映射到 javaBean 中。

需求说明

输入所生成 文件的存放路径、文件的名称(默认是表名)、包名(生成的是java文件,一定要指定包名)、是否使用lombok插件(考虑到自己实现getter/setter方法有一定的困难,直接借助lombok插件),判断每一个表中的字段的类型,生成一个标准的javaBean文件

实现

依赖

  1. jdk1.8
  2. mysql-connector-java 驱动包

实现方法

  1. 使用mysql-connector-java连接需要操作的数据库;
  2. 得到数据库中所有的表名;
  3. 根据表名和数据库名称得到表的字段以及字段的类型;
  4. 根据表名和字段的类型,生成目标文件最重要的部分内容;
  5. 一个创建文件并向文件输入内容的方法;
  6. 对上述方法进行封装!
  7. 测试+完工;
  8. 记录+完善。

假想的条件

  1. 数据库的表名使用 下划线区分各个单词 来命名,eg: registed_user , approved_user;
  2. 数据库中的字段也如同表名的命名一样;

show代码

文件结构说明

在这里插入图片描述

ConnectionUtil.java

得到数据库的连接

package connection;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class ConnectionUtil {
    
    public static Connection getConn(String dbName, String username, String password) {
    
        String driver = "com.mysql.jdbc.Driver";
        String url = "jdbc:mysql://localhost:3306/"+dbName+"?useUnicode=true&characterEncoding=utf-8&useSSL=false";
        Connection conn = null;
        try {
    
            Class.forName(driver); 
            conn = (Connection) DriverManager.getConnection(url, username, password);
        } catch (ClassNotFoundException e) {
    
            e.printStackTrace();
        } catch (SQLException e) {
    
            e.printStackTrace();
        }
        return conn;
    }
}

MapperUtil.java

这里写的是上述需要封装的所有方法

package mapper;

import connection.ConnectionUtil;

import java.io.BufferedOutputStream;
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.sql.*;
import java.util.*;

public class MapperUtil {
    
    private DatabaseMetaData databaseMetaData;
    Connection connection;

    public MapperUtil(String dbName, String username, String password) throws SQLException {
    
        connection = ConnectionUtil.getConn(dbName, username, password);
        databaseMetaData = connection.getMetaData();
    }

    /**
     * 只是文件名(不包含扩展名)
     * @param fileName 文件名称
     * @param dir 文件所处的目录
     * @param mainContent 文件的主要内容
     * @param isLombok 是否包含lombok常见的一些方法?包含:不包含
     */
    public void createFile(String fileName, String dir, String packagePath, String mainContent, boolean isLombok) throws Exception {
    
        if (fileName == null || fileName.trim().equals("") || dir == null || dir.trim().equals("")){
    
            throw new Exception("传入参数不正确");
        }
        /**
         * 1.首先检测是否有这个文件夹路径
         * 2.如果不存在则新建
         */
        File fileDir = new File(dir);
        if (!fileDir.exists()){
    
            fileDir.setWritable(true);
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
博客地址:http://blog.csdn.net/vipbooks 一直以来把数据库转换成Entity或DTO都是一件让人头痛的事情,既浪费时间又很繁琐,看着几十上百个的几百上千个字段,真是一件让人很头痛的事情。 我们也想过很多办法解决这个问题,包括用MyEclipse连接数据库生成JavaBean,但多多少少还是会有一些不尽人意的地方,包括字段的comment总是无法生成,而且还会生成很多无用的注释代码,让代码看起来一点都不干净,配置非常繁琐等等问题。 于是一怒之下,自己动手丰衣足食,就自己用Swing写了一个通过数据库生成JavaBean的工具,支持MySQL、Oracle、SQLServce、PostgreSQL,完美支持JPA注解,可以同时生成Entity和DTO,可以自动去除前缀,并支持去除多个前缀,支持精确指定只生成哪几个的Bean,也支持模糊查找生成哪几个的Bean,现在不但成员变量上能生成备注了,而且在Getter和Setter上也能有备注了! 更重要的是所有的配置都能被保存到本地,只要配置过一次,下次使用只要点一下生成JavaBean,下一秒就能拿到你想要的JavaBean了,完全实现秒生成。并且集成各种实用工具,使得工作效率瞬间爆棚,生产力瞬间爆! 该压缩包包含32位和64位两个版本。 第11版更新震撼发布,此次版本更新如下: 1、新增数据源配置管理功能,可以为每种类型的数据库添加多个不同的数据源。 2、新增快速新增数据源功能,快速为当前选数据库添加数据源。 3、新增打开目录功能,左键打开菜单选择要打开的目录,点击右键可以快速打开当前应用所在目录。 4、新增对使用驼峰命名的名和字段名的支持,例如名是UserInfo,生成Bean的类名也是UserInfo; 字段名是userId,那么生成的Bean字段也是userId。 5、主界面移除驱动名下拉选项,并新增快速切换数据源配置下拉选项。 6、改进精确匹配“更多”的选功能,在文本框已选在打开选对话框时会被勾选。 7、改进清除StringBuffer工具,选择SQL类型会自动将“//”替换为“--”。 8、改进字符串格式化工具,将有更多类型可选,操作更方便。 9、其他一些小Bug的修改和代码优化调整。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值