有关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();
}
}