JDBC读取数据库元数据,生成JAVA实体类

package com.lawrence.utils;
	import java.io.FileWriter;
	import java.io.IOException;
	import java.io.PrintWriter;
	import java.sql.Connection;
	import java.sql.PreparedStatement;
	import java.sql.ResultSetMetaData;
	import java.sql.SQLException;

	import com.lawrence.utils.DBHelp;

	public class GenEntityTool {
	    private String tablename = "bster_resource_video_document";

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

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

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

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

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

	    public GenEntityTool() {
	        Connection conn = DBHelp.getConnection(); // 得到数据库连接
	        String strsql = "select * from " + tablename;
	        try {
	            PreparedStatement pstmt = conn.prepareStatement(strsql);
	            ResultSetMetaData rsmd = pstmt.getMetaData();
	            int size = rsmd.getColumnCount(); // 共有多少列
	            colnames = new String[size];
	            colTypes = new String[size];
	            colSizes = new int[size];
	            for (int i = 0; i < rsmd.getColumnCount(); i++) {
	                colnames[i] = rsmd.getColumnName(i + 1);
	                colTypes[i] = rsmd.getColumnTypeName(i + 1);
	                if (colTypes[i].equalsIgnoreCase("datetime")) {
	                    f_util = true;
	                }
	                if (colTypes[i].equalsIgnoreCase("image")
	                        || colTypes[i].equalsIgnoreCase("text")) {
	                    f_sql = true;
	                }
	                colSizes[i] = rsmd.getColumnDisplaySize(i + 1);
	            }
	            String content = parse(colnames, colTypes, colSizes);
	            try {
	                FileWriter fw = new FileWriter(initcap(tablename) + ".java");
	                PrintWriter pw = new PrintWriter(fw);
	                pw.println(content);
	                pw.flush();
	                pw.close();
	            } catch (IOException e) {
	                e.printStackTrace();
	            }
	        } catch (SQLException e) {
	            e.printStackTrace();
	        } finally {
	        	DBHelp.closeConnection(conn);
	        }
	    }

	    /**
	    * 解析处理(生成实体类主体代码)
	    */
	    private String parse(String[] colNames, String[] colTypes, int[] colSizes) {
	        StringBuffer sb = new StringBuffer();
	        if (f_util) {
	            sb.append("import java.util.Date;\r\n");
	        }
	        if (f_sql) {
	            sb.append("import java.sql.*;\r\n\r\n\r\n");
	        }
	        sb.append("public class " + initcap(tablename) + " {\r\n");
	        processAllAttrs(sb);
	        processAllMethod(sb);
	        sb.append("}\r\n");
	        System.out.println(sb.toString());
	        return sb.toString();

	    }

	    /**
	    * 生成所有的方法
	    * 
	    * @param sb
	    */
	    private void processAllMethod(StringBuffer sb) {
	        for (int i = 0; i < colnames.length; i++) {
	            sb.append("\tpublic void set" + initcap(colnames[i]) + "("
	                    + sqlType2JavaType(colTypes[i]) + " " + colnames[i]
	                    + "){\r\n");
	            sb.append("\t\tthis." + colnames[i] + "=" + colnames[i] + ";\r\n");
	            sb.append("\t}\r\n");

	            sb.append("\tpublic " + sqlType2JavaType(colTypes[i]) + " get"
	                    + initcap(colnames[i]) + "(){\r\n");
	            sb.append("\t\treturn " + colnames[i] + ";\r\n");
	            sb.append("\t}\r\n");
	        }
	    }

	    /**
	    * 解析输出属性
	    * 
	    * @return
	    */
	    private void processAllAttrs(StringBuffer sb) {
	        for (int i = 0; i < colnames.length; i++) {
	            sb.append("\tprivate " + sqlType2JavaType(colTypes[i]) + " "
	                    + colnames[i] + ";\r\n");

	        }
	    }

	    /**
	    * 把输入字符串的首字母改成大写
	    * 
	    * @param str
	    * @return
	    */
	    private String initcap(String str) {
	        char[] ch = str.toCharArray();
	        if (ch[0] >= 'a' && ch[0] <= 'z') {
	            ch[0] = (char) (ch[0] - 32);
	        }
	        return new String(ch);
	    }

	    private String sqlType2JavaType(String sqlType) {
	        if (sqlType.equalsIgnoreCase("bit")) {
	            return "bool";
	        } else if (sqlType.equalsIgnoreCase("tinyint")) {
	            return "byte";
	        } else if (sqlType.equalsIgnoreCase("smallint")) {
	            return "short";
	        } else if (sqlType.equalsIgnoreCase("int")) {
	            return "int";
	        } else if (sqlType.equalsIgnoreCase("bigint")) {
	            return "long";
	        } else if (sqlType.equalsIgnoreCase("float")) {
	            return "float";
	        } else if (sqlType.equalsIgnoreCase("decimal")
	                || sqlType.equalsIgnoreCase("numeric")
	                || sqlType.equalsIgnoreCase("real")) {
	            return "double";
	        } else if (sqlType.equalsIgnoreCase("money")
	                || sqlType.equalsIgnoreCase("smallmoney")) {
	            return "double";
	        } else if (sqlType.equalsIgnoreCase("varchar")
	                || sqlType.equalsIgnoreCase("char")
	                || sqlType.equalsIgnoreCase("nvarchar")
	                || sqlType.equalsIgnoreCase("nchar")) {
	            return "String";
	        } else if (sqlType.equalsIgnoreCase("datetime")) {
	            return "Date";
	        }

	        else if (sqlType.equalsIgnoreCase("image")) {
	            return "Blob";
	        } else if (sqlType.equalsIgnoreCase("text")) {
	            return "Clob";
	        }
	        return null;
	    }

	    public static void main(String[] args) {
	        new GenEntityTool();
	    }
	}

<pre name="code" class="java">//数据库连接
</pre><p>package com.lawrence.utils;</p><p></p>import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;public class DBHelp {<span style="white-space: pre;"></span>public static Connection conn = null;<span style="white-space: pre;"></span><span style="white-space: pre;"></span>/**<span style="white-space: pre;"></span>*加载数据库驱动,获得数据库连接<span style="white-space: pre;"></span>*/<span style="white-space: pre;"></span>public static Connection getConnection(){<span style="white-space: pre;"></span>String driver = "com.microsoft.sqlserver.jdbc.SQLServerDriver";<span style="white-space: pre;"></span>String url = "jdbc:sqlserver://localhost:1433;databaseName=bstercstpresource";<span style="white-space: pre;"></span>String username = "sa";<span style="white-space: pre;"></span>String password = "123456";<span style="white-space: pre;"></span>try {<span style="white-space: pre;"></span>Class.forName(driver);<span style="white-space: pre;"></span>conn = DriverManager.getConnection(url,username,password);<span style="white-space: pre;"></span>} catch (Exception e) {<span style="white-space: pre;"></span>e.printStackTrace();<span style="white-space: pre;"></span>}<span style="white-space: pre;"></span>return conn;<span style="white-space: pre;"></span>}<span style="white-space: pre;"></span><span style="white-space: pre;"></span>/**<span style="white-space: pre;"></span>* 关闭数据库连接<span style="white-space: pre;"></span>*/<span style="white-space: pre;"></span>public static void closeConnection(Connection conn){<span style="white-space: pre;"></span>try {<span style="white-space: pre;"></span>if(conn != null){<span style="white-space: pre;"></span>conn.close();<span style="white-space: pre;"></span>}<span style="white-space: pre;"></span>} catch (SQLException e) {<span style="white-space: pre;"></span>e.printStackTrace();<span style="white-space: pre;"></span>}<span style="white-space: pre;"></span>}<span style="white-space: pre;"></span>}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值