内容概要:
ResultSetMetaData中的方法的介绍。
ResultSetMetaData:
这个类完成了查询结果信息和结果中的列的各种信息。它包含的方法以及各个方法的作用,在下面这个演示程序中一一介绍。在这个演示程序中用到数据库是Access的,数据库中的表的名字是STUDENTINFO表,包含字段有
IDNO 文本型 长为8
NAME 文本型 长为8
SEX 文本型 长为6
AGE 数值型 长为8
BIRTHDT 文本型 长为8
程序中主要是操作这个表,选择的驱动是ODBC。程序如下:
- importjava.sql.*;
- publicclassDBAccess{
- publicstaticjava.sql.Connectionconn=null;
- privateStringsqlStr="";
- publicDBAccess()
- {
- //newsun.jdbc.odbc.JdbcOdbcDriver();
- try{
- Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
- conn=DriverManager.getConnection("jdbc:odbc:TestDB","admin","");
- }
- catch(ClassNotFoundExceptionex){
- System.out.println(ex.toString());
- }
- catch(SQLExceptionsqlEx){
- System.out.println(sqlEx.toString());
- }
- }
- publicResultSetSearch(){
- ResultSetrset=null;
- sqlStr="SELECT*FROMSTUDENTINFO";
- Statementsmt=null;
- try{
- smt=conn.createStatement();
- rset=smt.executeQuery(sqlStr);
- }
- catch(SQLExceptionex){
- System.out.println("Exception:"+ex.toString());
- }
- returnrset;
- }
- publicvoidgetResultSetMetaData()
- {
- ResultSetrs=null;
- try{
- String[]tp={"TABLE"};
- rs=this.Search();
- ResultSetMetaDatarsmd=rs.getMetaData();
- System.out.println("下面这些方法是ResultSetMetaData中方法");
- System.out.println("获得1列所在的Catalog名字:"+rsmd.getCatalogName(1));
- System.out.println("获得1列对应数据类型的类"+rsmd.getColumnClassName(1));
- System.out.println("获得该ResultSet所有列的数目"+rsmd.getColumnCount());
- System.out.println("1列在数据库中类型的最大字符个数"+rsmd.getColumnDisplaySize(1));
- System.out.println("1列的默认的列的标题"+rsmd.getColumnLabel(1));
- System.out.println(“1列的模式”+rsmd.GetSchemaName(1));
- System.out.println("1列的类型,返回SqlType中的编号"+rsmd.getColumnType(1));
- System.out.println("1列在数据库中的类型,返回类型全名"+rsmd.getColumnTypeName(1));
- System.out.println("1列类型的精确度(类型的长度):"+rsmd.getPrecision(1));
- System.out.println("1列小数点后的位数"+rsmd.getScale(1));
- System.out.println("1列对应的模式的名称(应该用于Oracle)"+rsmd.getSchemaName(1));
- System.out.println("1列对应的表名"+rsmd.getTableName(1));
- System.out.println(“1列是否自动递增”+rsmd.isAutoIncrement(1));
- System.out.println(“1列在数据库中是否为货币型”+rsmd.isCurrency(1));
- System.out.println(“1列是否为空”+rsmd.isNullable(1));
- System.out.println(“1列是否为只读”+rsmd.isReadOnly(1));
- System.out.println(“1列能否出现在where中”+rsmd.isSearchable(1));
- }
- catch(SQLExceptionex){
- ex.printStackTrace();
- }
- }
- publicstaticvoidmain(Stringargs[])
- {
- DBAccessdbAccess=newDBAccess();
- dbAccess.getResultSetMetaData();
- }
- }
import java.sql.*;public class DBAccess { public static java.sql.Connection conn = null; private String sqlStr = "";public DBAccess() { //new sun.jdbc.odbc.JdbcOdbcDriver(); try { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); conn = DriverManager.getConnection("jdbc:odbc:TestDB","admin",""); } catch (ClassNotFoundException ex) { System.out.println(ex.toString()); } catch(SQLException sqlEx){ System.out.println(sqlEx.toString()); } }public ResultSet Search() { ResultSet rset = null; sqlStr = "SELECT * FROM STUDENTINFO"; Statement smt = null; try { smt = conn.createStatement(); rset = smt.executeQuery(sqlStr); } catch (SQLException ex) { System.out.println("Exception:"+ex.toString()); } return rset; } public void getResultSetMetaData(){ ResultSet rs = null; try { String[] tp = {"TABLE"}; rs = this.Search(); ResultSetMetaData rsmd = rs.getMetaData(); System.out.println("下面这些方法是ResultSetMetaData中方法"); System.out.println("获得1列所在的Catalog名字 : " + rsmd.getCatalogName(1)); System.out.println("获得1列对应数据类型的类 " + rsmd.getColumnClassName(1)); System.out.println("获得该ResultSet所有列的数目 " + rsmd.getColumnCount()); System.out.println("1列在数据库中类型的最大字符个数" + rsmd.getColumnDisplaySize(1)); System.out.println(" 1列的默认的列的标题" + rsmd.getColumnLabel(1)); System.out.println(“1列的模式” + rsmd.GetSchemaName(1)); System.out.println("1列的类型,返回SqlType中的编号 " + rsmd.getColumnType(1)); System.out.println("1列在数据库中的类型,返回类型全名" + rsmd.getColumnTypeName(1)); System.out.println("1列类型的精确度(类型的长度): " + rsmd.getPrecision(1)); System.out.println("1列小数点后的位数 " + rsmd.getScale(1)); System.out.println("1列对应的模式的名称(应该用于Oracle) " + rsmd.getSchemaName(1)); System.out.println("1列对应的表名 " + rsmd.getTableName(1)); System.out.println(“1列是否自动递增” + rsmd.isAutoIncrement(1)); System.out.println(“1列在数据库中是否为货币型” + rsmd.isCurrency(1)); System.out.println(“1列是否为空” + rsmd.isNullable(1)); System.out.println(“1列是否为只读” + rsmd.isReadOnly(1)); System.out.println(“1列能否出现在where中” + rsmd.isSearchable(1)); } catch (SQLException ex) { ex.printStackTrace();}}public static void main(String args[]) { DBAccess dbAccess = new DBAccess(); dbAccess.getResultSetMetaData(); }}
通过上面例子中的方法能够获得,ResultSet中的表的信息。