JDBC的那点事之DatabaseMetaData之获取数据库所有表 jdbc 获取数据库名

获取数据库的所有表:(以MySQL和Oracle为例,其他类型的数据库接触不过,不做解释)

Connection接口中提供了DatabaseMetaData接口:

提供:getTables()方法,该方法需要传进4个参数:

第一个是数据库名称,对于MySQL,则对应相应的数据库,对于Oracle来说,则是对应相应的数据库实例,可以不填,也可以直接使用Connection的实例对象中的getCatalog()方法返回的值填充;

第二个是模式,可以理解为数据库的登录名,而对于Oracle也可以理解成对该数据库操作的所有者的登录名。对于Oracle要特别注意,其登陆名必须是大写,不然的话是无法获取到相应的数据,而MySQL则不做强制要求。

第三个是表名称,一般情况下如果要获取所有的表的话,可以直接设置为null,如果设置为特定的表名称,则返回该表的具体信息。

第四个是类型标准,以数组形式传值,有"TABLE"、"VIEW"、"SYSTEM TABLE"、"GLOBALTEMPORARY"、"LOCAL TEMPORARY"、"ALIAS" 和"SYNONYM"这几个经典的类型,一般使用”TABLE”,即获取所有类型为TABLE的表

它返回一个ResultSet对象,有10列,详细的显示了表的类型:

TABLE_CAT String => 表类别(可为null)

TABLE_SCHEM String => 表模式(可为null)

TABLE_NAME String => 表名称

TABLE_TYPE———— String => 表类型。

REMARKS String => 表的解释性注释

TYPE_CAT String => 类型的类别(可为null)

TYPE_SCHEM String => 类型模式(可为null)

TYPE_NAME String => 类型名称(可为null)

SELF_REFERENCING_COL_NAME String=> 有类型表的指定 "identifier" 列的名称(可为 null)

REF_GENERATION String

可根据需要使用

示例:

(MySQL)

DatabaseMetaData metaData = conn.getMetaData();

ResultSet rs =metaData.getTables(conn.getCatalog(), "root", null,new String[]{"TABLE"});

while(rs.next()) {

System.out.println(rs.getString("TABLE_NAME"));

}

(Oracle)

DatabaseMetaData metaData = conn.getMetaData();
ResultSet rs = metaData.getTables(conn.getCatalog(), "SCOTT", null,new String[]{"TABLE"});
while(rs.next()) {
System.out.println(rs.getString("TABLE_NAME"));
JDBC的那点事之DatabaseMetaData之获取数据库所有表 jdbc 获取数据库名
}

这两处的代码,唯一区别的是在第二个参数,Oracle不支持小写的,必须是大写的,换成小写则什么都获取不到,而MySQL则大小写俱可,不过我建议是全部使用大写,这里只是示例······

  

爱华网本文地址 » http://www.413yy.cn/a/25101016/291361.html

更多阅读

两性图文===男女那点事 两性人视频播放

男女那点事男女那点事,说高尚点,就是爱情和婚姻,说俗气点,就是床上一点事,床下一堆事。男女那点事,其实就是这么一回事,套用鲁迅先生的名言:男女之间本没有事,说的人多了,也就有了事。男女那点事,说大不大,说小不小,但如果处理不好,不但男人受累,女

揭关羽与貂蝉的那点事 关羽斩貂蝉

中国文人的骨子里都希望:男子个个是英雄,女子个个是贤妻。按照中国文人的说法,“声妓晚景从良,十年之烟花无碍;贞妇白头失节,—世之清名俱非”。这是千百年来,中国文人的贞节观。民间传说中“西施随范蠡,关羽纳貂蝉”——中国民间,将“四大美

大学的那点事给女生起外号 叫女生什么外号好听

大学的生活自由又荒唐,印象最深的是给女生们起外号,那时我们火箭班入学的时候有21人,其中女生6人,女生中有三个是北京的,刚进校的时候我因为报到早一点当上了班长,不过我还是很卖力的,当时我们班还是很有凝聚力的,这个就不提了,说说那班女生

声明:《JDBC的那点事之DatabaseMetaData之获取数据库所有表 jdbc 获取数据库名》为网友镹疎問候分享!如侵犯到您的合法权益请联系我们删除