在协作开发过程,特别是跨公司合作开发中,表的设计方和使用方完全不同。有时你需要知道表的结构,由于种种原因,一时无法得知表设计信息。
现在JDBC的ResultSetMetaData对象可以帮你获取表的信息。
ResultSetMetaData是ResultSet接口的成员,提供了获取表字段的方法。
常见的方法有:
方法 说明
getColumnCount() 获取总字段数据
getTableName(1) 获取表名
getColumnName(i) 获取指定列字段名,该字段在表内的名称
getColumnTypeName(i) 获取指定列字段数据类型
getTableName(i) 获取指定列字段标签,SQL语句中要求的该字段的名称
getSchemaName(i) 获取指定列字段数据库模式
getPrecision(i) 获取指定列字段小数点前几位
getScale(i) 获取指定列字段小数点后几位
getColumnDisplaySize(i) 获取指定列字段字段长度
isAutoIncrement(i) 获取指定列字段是否自动递增
isNullable(i) 获取指定列字段是否允许空值
下面的示例演示了获取表字段的用法。
public static void main(String[] args) {
String url = “jdbc:mysql://127.0.0.1:3306/northwind”;
String user = “northwind”;
String password = “northwind”;
try (Connection connection = DriverManager.getConnection(url, user, password)) {
PreparedStatement statement = connection.prepareStatement("SELECT * FROM employees;");
ResultSet rs = statement.executeQuery();
//从ResultSet对象中获取ResultSetMetaData对象
ResultSetMetaData meta = rs.getMetaData();
int cols = meta.getColumnCount();
System.out.println("总列: " + cols);
System.out.println("表名: " + meta.getTableName(1));
System.out.println();
for (int i = 1; i <= cols; i++) {
System.out.println("字段名: " + meta.getColumnName(i));
System.out.println("数据类型: " + meta.getColumnTypeName(i));
System.out.println("标签: " + meta.getTableName(i));
System.out.println("数据库模式: " + meta.getSchemaName(i));
System.out.println("小数点前几位: " + meta.getPrecision(i));
System.out.println("小数点后几位: " + meta.getScale(i));
System.out.println("字段长度: " + meta.getColumnDisplaySize(i));
System.out.println("是否自动递增:" + meta.isAutoIncrement(i));
System.out.println("是否允许空值:" + meta.isNullable(i));
System.out.println();
}
} catch (SQLException e) {
e.printStackTrace();
}
}