表的信息的获得---ResultSetMetaData

原创 2006年05月27日 20:13:00
数据库中信息和表的信息的获得的问题,如:数据库中有多少表,表中的字段的含义等,为了解决这个问题我学习了相关的两个类ResultSetMetaDataDataBaseMetaData来解决相关问题。下面是我的一些学习的心得体会,希望能够给朋友们带来一点启示或者帮助。首先是ResultSetMetaData

这个类完成了查询结果信息和结果中的列的各种信息。它包含的方法以及各个方法的作用,在下面这个演示程序中一一介绍。在这个演示程序中用到数据库是Access的,数据库中的表的名字是STUDENTINFO表,包含字段有

IDNO 文本型 长为8

NAME 文本型 长为8

SEX 文本型 长为6

AGE 数值型 长为8

BIRTHDT 文本型 长为8

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

 

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();   

/*

获得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();

  }

}

java通过ResultSetMetaData获取数据库的列。

java通过ResultSetMetaData获取数据库的列。
  • en_joker
  • en_joker
  • 2017年09月04日 22:54
  • 283

ResultSetMetaData 中的方法介绍

ResultSetMetaData 中的方法介绍 利用ResultSet的getMetaData的方法可以获得ResultSetMeta对象,而ResultSetMetaData存储了 Resu...
  • my543843165
  • my543843165
  • 2016年09月01日 10:48
  • 1495

关于ResultSetMetaData获取列名不一致的问题

ResultSetMetaData 获取列名
  • u011722519
  • u011722519
  • 2015年01月05日 08:48
  • 1174

表的信息的获得---ResultSetMetaData

在论坛中看到有好多人问关于 ,数据库中信息和表的信息的获得的问题 ,如 :数据库中有多少表 ,表中的字段的含义等 。     为了解决这个问题我学习了相关的两个类ResultSetMetaData和D...
  • yangm1203
  • yangm1203
  • 2007年07月30日 21:51
  • 509

04_关于元数据,ResultSetMetaData对象以及API方法介绍

 ResultSetMetaData对象 元数据,可以理解为数据的数据 Jdbc中的元数据是指数据库、表、列的定义信息。 ResultSetMetaData对象表示结果集R...
  • toto1297488504
  • toto1297488504
  • 2014年12月08日 21:56
  • 958

DatabaseMetaData ResultSet ResultSetMetaData三种类型的区别

DatabaseMetaData,ResultSet,ResultSetMetaData三种类型的区别 1、DatabaseMetaData 有关整个数据库的信息:数据库产品的名称和版本,数据库中表和...
  • suwu150
  • suwu150
  • 2016年10月05日 01:37
  • 2127

查询mysql数据表 获得表详细信息

public static void main(String[] args) throws Exception { Connection connection = DBConnectio...
  • hai4321
  • hai4321
  • 2017年04月19日 17:57
  • 302

使用DataBaseMetaData得到表的主键

try {   String user = "ahcwtest";   String password = "ahcwtest";   String driver= "oracle.jdbc.driv...
  • wonder4
  • wonder4
  • 2006年10月19日 14:11
  • 2850

【转载】ResultSet、ResultSetMetaData 用法详细说明

原文转自:http://www.cnblogs.com/chinafine/articles/1847205.html DatabaseMetaData 有关整个数据库的信息:表名、表的索引、数据库...
  • u011704894
  • u011704894
  • 2015年04月10日 10:41
  • 2059

[疯狂Java]JDBC:ResultSetMetaData(结果集元数据分析)

1.
  • Lirx_Tech
  • Lirx_Tech
  • 2016年04月14日 15:57
  • 1114
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:表的信息的获得---ResultSetMetaData
举报原因:
原因补充:

(最多只允许输入30个字)