在这个演示程序中用到数据库是Access的数据库中的表的名字是STUDENTINFO表包含字段有 IDNO 文本型 长为 NAME 文本型 长为 SEX 文本型 长为 AGE 数值型 长为 BIRTHDT 文本型 长为 程序中主要是操作这个表选择的驱动是ODBC程序如下 import javasql*; public class DBAccess { public static javasqlConnection conn = null; private String sqlStr = ; public DBAccess() { //new sunjdbcodbcJdbcOdbcDriver(); try { ClassforName(sunjdbcodbcJdbcOdbcDriver); conn = DriverManagergetConnection(jdbc:odbc:TestDBadmin); } catch (ClassNotFoundException ex) { Systemoutprintln(extoString()); } catch(SQLException sqlEx){ Systemoutprintln(sqlExtoString()); } } public ResultSet Search(){ ResultSet rset = null; sqlStr = SELECT * FROM STUDENTINFO; Statement smt = null; try { smt = conncreateStatement(); rset = smtexecuteQuery(sqlStr); } catch (SQLException ex) { Systemoutprintln(Exception:+extoString()); } return rset; } public void getResultSetMetaData() { ResultSet rs = null; try { String[] tp = {TABLE}; rs = thisSearch(); ResultSetMetaData rsmd = rsgetMetaData(); /* 获得ResultSetMeataData对象所有方法的参数都是列的索引号即第几列从开始 */ Systemoutprintln(下面这些方法是ResultSetMetaData中方法); Systemoutprintln(获得列所在的Catalog名字 : + rsmdgetCatalogName()); Systemoutprintln(获得列对应数据类型的类 + rsmdgetColumnClassName()); Systemoutprintln(获得该ResultSet所有列的数目 + rsmdgetColumnCount()); Systemoutprintln(列在数据库中类型的最大字符个数 + rsmdgetColumnDisplaySize()); Systemoutprintln( 列的默认的列的标题 + rsmdgetColumnLabel()); Systemoutprintln(列的模式 + rsmdGetSchemaName()); Systemoutprintln(列的类型返回SqlType中的编号 + rsmdgetColumnType()); Systemoutprintln(列在数据库中的类型返回类型全名 + rsmdgetColumnTypeName()); Systemoutprintln(列类型的精确度(类型的长度): + rsmdgetPrecision()); Systemoutprintln(列小数点后的位数 + rsmdgetScale()); Systemoutprintln(列对应的模式的名称(应该用于Oracle) + rsmdgetSchemaName()); Systemoutprintln(列对应的表名 + rsmdgetTableName()); Systemoutprintln(列是否自动递增 + rsmdisAutoIncrement()); Systemoutprintln(列在数据库中是否为货币型 + rsmdisCurrency()); Systemoutprintln(列是否为空 + rsmdisNullable()); Systemoutprintln(列是否为只读 + rsmdisReadOnly()); Systemoutprintln(列能否出现在where中 + rsmdisSearchable()); } catch (SQLException ex) { exprintStackTrace(); } } public static void main(String args[]) { DBAccess dbAccess = new DBAccess(); dbAccessgetResultSetMetaData(); } } 通过上面例子中的方法能够获得ResultSet中的表的信息有两个方法的用法我也不甚清楚所以没写弄明白了再作补充 |