Java中Oracle生成实体类的工具代码

java将ORACLE数据库中的表生成对应的实体类


package com.util;

import java.io.FileWriter;

import java.io.IOException;

import java.io.PrintWriter;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.ResultSet;

import java.sql.ResultSetMetaData;

import java.sql.SQLException;

import java.sql.Statement;

/**

* 根据数据库表结构生成相应的JavaBean

*

* 思路

* 1、创建数据库连接

* 2、获取数据库表、表注释

* 3、获取数据库表中字段名、字段类型、字段注释

* 4、构建StringBuffer缓存

* 5、写入文件

* 6、关闭连接、输入流等等

*

* @author ella_li

*

*/

public class GenEntityOracle {

    private String packageOutPath = "D:/";// 指定实体生成所在包的路径

    private String tableName = "HOUSE_REGISTER";//数据库中的表名

    private String packageName = "com.ufgov.wcx.entity";//实体类所在的包

    //private String authorName = "wcx";// 作者名字

    private String[] colsPre = { "F_NB_", "F_VC_", "F_CR_", "F_DT_"};

    private String[] colnames; // 列名数组

    private String[] colTypes; // 列名类型数组

    private int[] colSizes; // 列名大小数组

    private boolean f_util = false; // 是否需要导入包java.util.*

    private boolean f_sql = false; // 是否需要导入包java.sql.*

    // 数据库连接

    private static final String URL = "jdbc:oracle:thin:@127.0.0.1:1521:orcl";

    private static final String NAME = "scott";

    private static final String PASS = "1";

    private static final String DRIVER = "oracle.jdbc.driver.OracleDriver";

    private Connection con = null;

    private Statement pStemt = null;

    private ResultSet rs = null;

    private ResultSetMetaData rsmd = null;

    public GenEntityOracle() {

        connect();

        getTableInfo(tableName);

        colseConnect();

    }

    /**

    * 1、创建数据库连接

    */

    private void connect() {

        try {

            Class.forName(DRIVER);

            con = DriverManager.getConnection(URL, NAME, PASS);

            pStemt = (Statement) con.createStatement();

        } catch (ClassNotFoundException | SQLException e) {

            e.printStackTrace();

        }

    }

    private void colseConnect() {

        try {

            if (con != null) {

                con.close();

                con = null;

            }

            if (pStemt != null) {

                pStemt.close();

                pStemt = null;

            }

        } catch (SQLException e) {

            e.printStackTrace();

        }

    }

    /**

    * 获取单个数据库表信息

    */

    private void getTableInfo(String tableName) {

        int size = 0;

        String sql = "SELECT * FROM " + tableName;

        try {

            rs = pStemt.executeQuery(sql);

            rsmd = rs.getMetaData();

            size = rsmd.getColumnCount();

            colnames = new String[size];

            colTypes = new String[size];

            colSizes = new int[size];

            for (int i = 0; i < size; i++) {

                colnames[i] = rsmd.getColumnName(i + 1);

                colTypes[i] = rsmd.getColumnTypeName(i + 1);

                if (colTypes[i].equalsIgnoreCase("date")

                        || colTypes[i].equalsIgnoreCase("timestamp")) {

                    f_util = true;

                }

                if (colTypes[i].equalsIgnoreCase("blob")

                        || colTypes[i].equalsIgnoreCase("char")) {

                    f_sql = true;

                }

                colSizes[i] = rsmd.getColumnDisplaySize(i + 1);

            }

            //获取单张数据库表注释

            String tableComment = getTableComment(tableName);

            //获取单张数据库表的所有列信息

            StringBuffer tempSb = getColsInfo(tableName);

            //生成JavaBean文件

            genFile(tableName, getSb(tableName, tableComment, tempSb));

        } catch (SQLException e) {

            e.printStackTrace();

        }

    }

    /**

    * 获取单张数据库表注释

    *

    * @param tableName

    * @return

    */

    private String getTableComment(String tableName) {

        String str = "";

        String sql = "select * from user_tab_comments where table_name = '"

                + tableName + "'";

        try {

            rs = pStemt.executeQuery(sql);

            while (rs.next()) {

                str = rs.getString("comments");

                if (null != str && str.indexOf("\r\n") != -1) {

                    str = str.replace("\r\n", "");

                }

                if (null != str && str.indexOf("\n") != -1) {

                    str = str.replace("\n", "");

                }

            }

        } catch (SQLException e) {

            e.printStackTrace();

        }

        return str;

    }

    /**

    * 获取单张数据库表的所有列信息

    *

    * @param tableName

    */

    private StringBuffer getColsInfo(String tableName) {

        StringBuffer temp = new StringBuffer();

        for (int i = 0; i < colnames.length; i++) {

            temp.append("\tprivate " + getColsType(colTypes[i]) + " "

                    + getColsName(colnames[i]) + ";  //"

                    + getColComment(tableName, colnames[i]) + "\r\n");

            String colname = getColsName(colnames[i]);

            String colnameUp = captureName(colname);

            temp.append("\n\tpublic void set" + colnameUp + "("

                    + getColsType(colTypes[i]) + " " + colname + "){\r\n");

            temp.append("\t\tthis." + colname + "=" + colname + ";\r\n");

            temp.append("\t}\r\n");

            temp.append("\n\tpublic " + getColsType(colTypes[i]) + " get"

                    + colnameUp + "(){\r\n");

            temp.append("\t\treturn " + colname + ";\r\n");

            temp.append("\t}\r\n");

        }

        return temp;

    }

    /**

    * 获取列类型

    *

    * @param sqlType

    * @return

    */

    private String getColsType(String sqlType) {

        if (sqlType.equalsIgnoreCase("binary_double")) {

            return "double";

        } else if (sqlType.equalsIgnoreCase("binary_float")) {

            return "float";

        } else if (sqlType.equalsIgnoreCase("blob")) {

            return "byte[]";

        } else if (sqlType.equalsIgnoreCase("blob")) {

            return "byte[]";

        } else if (sqlType.equalsIgnoreCase("char")

                || sqlType.equalsIgnoreCase("nvarchar2")

                || sqlType.equalsIgnoreCase("varchar2")) {

            return "String";

        } else if (sqlType.equalsIgnoreCase("date")

                || sqlType.equalsIgnoreCase("timestamp")

                || sqlType.equalsIgnoreCase("timestamp with local time zone")

                || sqlType.equalsIgnoreCase("timestamp with time zone")) {

            return "Date";

        } else if (sqlType.equalsIgnoreCase("number")) {

            return "Long";

        }

        return "String";

    }

    /**

    * 获取列名

    *

    * @param str

    * @return

    */

    private String getColsName(String str) {

        for (String temp : colsPre) {

            int preIndex = str.indexOf(temp);

            if (preIndex >= 0) {

                str = str.substring(preIndex + temp.length());

                str = str.replace("_", "").toLowerCase();

            }

        }

        return str;

    }

    /**

    * 获取列注释

    *

    * @param tableName

    * @param columnName

    * @return

    */

    private String getColComment(String tableName, String columnName) {

        String str = "";

        String sql = "select comments from USER_COL_COMMENTS where table_name= '"

                + tableName + "' and column_name= '" + columnName + "'";

        try {

            rs = pStemt.executeQuery(sql);

            while (rs.next()) {

                str = rs.getString("comments");

                if (null != str && str.indexOf("\r\n") != -1) {

                    str = str.replace("\r\n", "");

                }

                if (null != str && str.indexOf("\n") != -1) {

                    str = str.replace("\n", "");

                }

            }

        } catch (SQLException e) {

            e.printStackTrace();

        }

        return str;

    }

    /**

    * 构建StringBuffer缓存

    *

    * @param tableName

    * @param tableComment

    * @param colSb

    * @return

    */

    private StringBuffer getSb(String tableName, String tableComment,

            StringBuffer colSb) {

        StringBuffer sb = new StringBuffer();

        sb.append("package " + this.packageName + ";\r\n");

        // 判断是否导入工具包

        if (f_util) {

            sb.append("import java.util.Date;\r\n");

        }

        if (f_sql) {

            sb.append("import java.sql.*;\r\n");

        }

        sb.append("\r\n");

        // 注释部分

        //sb.append("  /**\r\n");

        //sb.append("    * " + tableName + " 实体类              " + tableComment + "\r\n");

        //sb.append("    * " + new Date() + "\r\n");

        //sb.append("    * @author " + this.authorName + "\r\n");

        //sb.append("    */ \r\n");

        // 实体部分

        sb.append("\r\n\r\npublic class " + tableName + "{\r\n");

        sb.append("\tprivate static final long serialVersionUID = 1L;\r\n");

        sb.append(colSb);

        sb.append("}\r\n");

        return sb;

    }

    /**

    * 生成JavaBean文件

    *

    * @param content

    */

    private void genFile(String tableName, StringBuffer content) {

        try {

            String outputPath = this.packageOutPath + tableName

                    + ".java";

            FileWriter fw = new FileWriter(outputPath);

            PrintWriter pw = new PrintWriter(fw);

            pw.println(content);

            pw.flush();

            pw.close();

        } catch (IOException e) {

            e.printStackTrace();

        }

    }

        /**

    * 首字母大写

    * @param name

    * @return

    */

    public static String captureName(String name) {

        char[] cs = name.toCharArray();

        //首字母是小写的需要大写

        if(cs[0] >= 97 && cs[0] <= 122) {

            cs[0] -= 32;

        }

        return String.valueOf(cs);

    }

    /**

    * 出口 TODO

    *

    * @param args

    */

    public static void main(String[] args) {

        new GenEntityOracle(); 

    }

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343