有时候我们想要获取到数据库的基本信息,当前程序连接的那个数据库,数据库的版本信息,数据库中有哪些表,表中都有什么字段,字段都是什么类型。等等一些信息,我们称之为数据库的元数据信息。实际开发中hibernate等orm框架或者代码生成器都是通过元数据信息获取库、表的信息进行封装和操作。
元数据主要有三种:
DatabaseMetaData元数据信息(获取数据库的信息)
ResultSetMetaData 元数据信息(操作的表的元数据信息)
ParameterMetaData元数据信息(参数的元数据信息)
本文下面的connection获取都是基于mysql数据库连接池使用(二)实现自己的数据库连接池实现的,不懂的可以参考,下面开始我们的学习之旅吧。
获取数据库的元数据信息:
Connection con = JdbcUtils.getConnection(true);
// 数据库元数据信息
DatabaseMetaData dmd = con.getMetaData();
String version = dmd.getDatabaseProductVersion();
System.out.println("数据库版本" + version);
String name = dmd.getDatabaseProductName();
System.out.println("数据库名称 " + name);
String driverName = dmd.getDriverName();
System.out.println("驱动名称 " + driverName);
测试:
08:21:06.568 [main] DEBUG cn.xhgg.test.DataSourceManager - DefaultConnectionPoolName is 3000...
08:21:06.632 [main] DEBUG cn.xhgg.test.DataSourceManager - Init DataSource 3000...
08:21:06.633 [main] DEBUG cn.xhgg.test.DataSourceManager - Init DataSource 5000...
数据库版本5.6.24
数据库名称 MySQL
驱动名称 MySQL Connector Java
获取此 ResultSet 对象的列的编号、类型和属性。
主要是获取ResultSet中数据库表中的所以字段信息:
数据库表的定义如下图:
代码如下:
String sql = "select * from test1";
Connection con = JdbcUtils.getConnection(true);
PreparedStatement pst = con.prepareStatement(sql);
ResultSet rs = pst.executeQuery();
// 得到结果集元数据对象
ResultSetMetaData rmd = rs.getMetaData();
if (rs.next()) {
// 得到每条记录有几列
//操作的表一共有多少字段
int count = rmd.getColumnCount();
System.out.println(count);
for (int i = 0; i < count; i++) {
String name = rmd.getColumnName(i + 1); // 根据列号得到每一列的名称
String columnTypeName = rmd.getColumnTypeName(i + 1);
System.out.print(name + " "+columnTypeName);
int type = rmd.getColumnType(i + 1);
System.out.println(type);
System.out.println("------------------------");
}
}
输出如下:
08:38:55.990 [main] DEBUG cn.xhgg.test.DataSourceManager - DefaultConnectionPoolName is 3000...
08:38:56.059 [main] DEBUG cn.xhgg.test.DataSourceManager - Init DataSource 3000...
08:38:56.060 [main] DEBUG cn.xhgg.test.DataSourceManager - Init DataSource 5000...
3
id INT4
------------------------
name VARCHAR12
------------------------
age INT4
------------------------
获取此 PreparedStatement 对象的参数的编号、类型和属性
ParameterMetaData主要可以获取到用户传入的参数的一些元数据信息如下:
代码如下:
String sql = "select * from test1 where name=?";
Connection con = JdbcUtils.getConnection(true);
PreparedStatement pst = con.prepareStatement(sql);
pst.setString(1, "1");
pst.executeQuery();
// 关于当前要操作的sql语句中的参数相关信息
ParameterMetaData pmd = pst.getParameterMetaData();
// 得要要执行的sql语句中有几个?
int count = pmd.getParameterCount();
System.out.println(count);