表的信息的获得---ResultSetMetaData

在论坛中看到有好多人问关于 ,数据库中信息和表的信息的获得的问题 ,如 :数据库中有多少表 ,表中的字段的含义等 。

     为了解决这个问题我学习了相关的两个类ResultSetMetaData和DataBaseMetaData来解决相关问题 。下面是我的一些学习的心得体会 。

     希望能够给朋友们带来一点启示或者帮助 。首先是

     ResultSetMetaData :

     这个类完成了查询结果信息和结果中的列的各种信息 。它包含的方法以及各个方法的作用 ,在下面这个演示程序中一一介绍 。

     在这个演示程序中用到数据库是Access的 ,数据库中的表的名字是STUDENTINFO表 ,包含字段有

     IDNO 文本型 长为8

     NAME 文本型 长为8

     SEX 文本型 长为6

     AGE 数值型 长为8

     BIRTHDT 文本型 长为8

     程序中主要是操作这个表 ,选择的驱动是ODBC 。程序如下 :

package javax.util.guxing;

import java.sql.*;

public class DBAccess {

   public static java.sql.Connection conn = null;

   private String sqlStr = "";

   public DBAccess() {
     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 STUDENTINF ";
     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();
       /*
        获得ResultSetMeataData对象。所有方法的参数都是列的索引号,即第几列,从1开始
        */
       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();
   }
}

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值