《DatabaseMetaData和ResultSetMetaData用法实例》

有关DatabaseMetaData的用法

一  、得到这个对象的实例

  String driverName = "oracle.jdbc.driver.OracleDriver";

  String url="jdbc:oracle:thin:@192.168.10.119:1521:test";

  String userName = "test";

  String password = "test";  

  Connection con = null;

   Class.forName(driverName);

   con = DriverManager.getConnection(url,userName,password);

   DatabaseMetaData dbmd = con.getMetaData();

二、方法getTables的用法

 原型:ResultSet DatabaseMetaData.getTables(String catalog,String schema,String tableName,String []type)

功能描述:得到指定参数的表信息

参数说明:

     参数:catalog:目录名称,一般都为空.

    参数:schema:数据库名,对于oracle来说就用户名

   参数:tablename:表名称

   参数:type :表的类型(TABLE | VIEW)

注意:在使用过程中,参数名称必须使用大写的。否则得到什么东西。

三、方法getColumns的用法

功能描述:得到指定表的列信息。

原型:ResultSet DatabaseMetaData getColumns(String catalog,String schema,String tableName,String columnName)

参数说明:

 参数catalog : 类别名称

参数schema : 用户方案名称

参数tableName : 数据库表名称

参数columnName : 列名称 

四、方法getPrimaryKeys的用法

功能描述:得到指定表的主键信息。

原型:ResultSet DatabaseMetaData getPrimaryKeys(String catalog,String schema,String tableName)

参数说明:

参数catalog : 类别名称

参数schema : 用户方案名称

参数tableName : 数据库表名称

备注:一定要指定表名称,否则返回值将是什么都没有。

五、方法.getTypeInfo()的用法

功能描述:得到当前数据库的数据类型信息。

六、方法getExportedKeys的用法

功能描述:得到指定表的外键信息。

参数描述:

参数catalog : 类别名称

参数schema : 用户方案名称

参数tableName : 数据库表名称

 

ResultSetMetaData主要获取表本身的结构

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

 }

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值