文章目录
  1. 1. 一、DatabaseMetaData
  2. 2. 二、ParameterMetaData
  3. 3. 三、ResultSetMetaData

本篇介绍数据库方面的元数据(MetaData)的有关知识。元数据在建立框架和架构方面是特别重要的知识,再下一篇我们仿造开源数据库工具类DbUtils就要使用数据库的元数据来创建自定义JDBC框架。

  在我们前面使用JDBC来处理数据库的接口主要有三个,即Connection,PreparedStatement和ResultSet这三个,而对于这三个接口,还可以获取不同类型的元数据,通过这些元数据类获得一些数据库的信息。

  元数据(MetaData),即定义数据的数据。打个比方,就好像我们要想搜索一首歌(歌本身是数据),而我们可以通过歌名,作者,专辑等信息来搜索,那么这些歌名,作者,专辑等等就是这首歌的元数据。因此数据库的元数据就是一些注明数据库信息的数据。

  ① 由Connection对象的getMetaData()方法获取的是DatabaseMetaData对象。

  ② 由PreparedStatement对象的getParameterMetaData ()方法获取的是ParameterMetaData对象。

  ③由ResultSet对象的getMetaData()方法获取的是ResultSetMetaData对象。

一、DatabaseMetaData

DatabaseMetaData是由Connection对象通过getMetaData方法获取而来,主要封装了是对数据库本身的一些整体综合信息,例如数据库的产品名称,数据库的版本号,数据库的URL,是否支持事务等等,能获取的信息比较多,具体可以参考DatabaseMetaData的API文档。

  以下有一些关于DatabaseMetaData的常用方法:

  ·getDatabaseProductName:获取数据库的产品名称

  ·getDatabaseProductName:获取数据库的版本号

  ·getUserName:获取数据库的用户名

  ·getURL:获取数据库连接的URL

  ·getDriverName:获取数据库的驱动名称

  ·driverVersion:获取数据库的驱动版本号

  ·isReadOnly:查看数据库是否只允许读操作

  ·supportsTransactions:查看数据库是否支持事务

例1:

  简单地获取一些常用的数据库综合信息。

二、ParameterMetaData

  ParameterMetaData是由PreparedStatement对象通过getParameterMetaData方法获取而来,主要是针对PreparedStatement对象和其预编译的SQL命令语句提供一些信息,比如像”insert into account(id,name,money) values(?,?,?)”这样的预编译SQL语句,ParameterMetaData能提供占位符参数的个数,获取指定位置占位符的SQL类型等等,功能也比较多,这里不列举完,详细请看有关ParameterMetaData的API文档。

  以下有一些关于ParameterMetaData的常用方法:

  ·getParameterCount:获取预编译SQL语句中占位符参数的个数

  在我看来,ParameterMetaData对象能用的只有获取参数个数的getParameterCount()方法。

注意:ParameterMetaData许多方法MySQL并不友好支持,比如像获取指定参数的SQL类型的getParameterType方法,如果数据库驱动连接URL只是简单的“jdbc:mysql://localhost:3306/jdbcdemo”那么MyEclipse会抛出SQLException异常,必须要将URL修改为“jdbc:mysql://localhost:3306/jdbcdemo?generateSimpleParameterMetadata=true”才行。但是像getParameterType等等与其他的方法也没多好用,因为如下面的例子,这些方法好像只会将所有的参数认为是字符串(VARCHAR)类型。

因为我们的SQL语句为”insert into user(id,name,age) values(?,?,?)”,而我们所有利用ParameterMetaData查询的信息除了参数个数以外,都是查询第一个参数的信息,也就是“id”列,而这个“id”列我们创建时是int整型的,但是利用ParameterMetaData的查询结果都是显示为字符串类型,因此我对ParameterMetaData的功能产生了怀疑。

  因此在以后使用参数元数据ParameterMetaData尽量只要使用其getParamterCount()方法获取参数个数,对于该对象其他方法请慎用。

三、ResultSetMetaData

  ResultSetMetaData是由ResultSet对象通过getMetaData方法获取而来,主要是针对由数据库执行的SQL脚本命令获取的结果集对象ResultSet中提供的一些信息,比如结果集中的列数、指定列的名称、指定列的SQL类型等等,可以说这个是对于框架来说非常重要的一个对象。关于该结果集元数据对象的其他具体功能和方法请查阅有关ResultSetMetaData的API文档。

以下有一些关于ResultSetMetaData的常用方法:

  ·getColumnCount:获取结果集中列项目的个数

  ·getColumnType:获取指定列的SQL类型对应于Java中Types类的字段

  ·getColumnTypeName:获取指定列的SQL类型

  ·getClassName:获取指定列SQL类型对应于Java中的类型(包名加类名)

文章目录
  1. 1. 一、DatabaseMetaData
  2. 2. 二、ParameterMetaData
  3. 3. 三、ResultSetMetaData