分类: Java
2006-03-28 00:40:35
JDBC中通过MetaData来获取具体的表的相关信息。可以查询数据库中的有哪些表,表有哪些字段,字段的属性等等。MetaData中通过一系列getXXX函数,将这些信息存放到ResultSet里面,然后返回给用户。关于MetaData的说明网上也有不少,这里我只是从我自身学习的角度来记录一下简单使用JDBC以及获取数据表相关信息的方法。 首先, 这里有篇名字叫做《Understanding JDBC MetaData》的文章,讲解得不错。 下面就是我的JDBC下的获取表信息的代码了。我是以MySQL 5.0作为测试平台的。 1. JDBC连接MYSQL的代码很标准,很简单。 class.forName("com.mysql.jdbc.Driver").newInstance(); 2. 下面就是获取表的信息。 m_DBMetaData = m_Connection.getMetaData(); 3. 提取表的名字。while(tableRet.next) System.out.println(tableRet.getString("TABLE_NAME")); 通过getString("TABLE_NAME"),就可以获取表的名字了。 4. 提取表内的字段的名字和类型 String columnName; JDBC里面通过getColumns的接口,实现对字段的查询。跟getTables一样,"%"表示所有任意的(字段),而m_TableName就是数据表的名字。 getColumns的返回也是将所有的字段放到一个类似的内存中的表,而COLUMN_NAME就是字段的名字,TYPE_NAME就是数据类型,比如"int","int unsigned"等等,COLUMN_SIZE返回整数,就是字段的长度,比如定义的int(8)的字段,返回就是8,最后NULLABLE,返回1就表示可以是Null,而0就表示Not Null。 |