JDBC的那点事之DatabaseMetaData之获取数据库所有表
2017-11-24 20:47
1581 查看
来源于:http://blog.sina.com.cn/s/blog_707a9f0601014y1a.html
获取数据库的所有表:(以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"));
}
这两处的代码,唯一区别的是在第二个参数,Oracle不支持小写的,必须是大写的,换成小写则什么都获取不到,而MySQL则大小写俱可,不过我建议是全部使用大写,这里只是示例
获取数据库的所有表:(以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"));
}
这两处的代码,唯一区别的是在第二个参数,Oracle不支持小写的,必须是大写的,换成小写则什么都获取不到,而MySQL则大小写俱可,不过我建议是全部使用大写,这里只是示例
相关文章推荐
- JDBC的那点事之DatabaseMetaData之获取数据库所有表
- JDBC的那点事之DatabaseMetaData之获取数据库所有表
- JDBC的那点事之DatabaseMetaData之获取表的所有列名
- JDBC的那点事之DatabaseMetaData之获取表的所有列名
- DatabaseMetaData之获取数据库所有表
- JDBC之DatabaseMetaData之获取表的所有列名
- JDBC(5)ResSetMetaData&DatabaseMetaData&获取数据库主键的值
- DatabaseMetaData 动态获取数据库表信息
- JDBC利用DatabaseMetaData,ResultSetMetaData获取数据库连接信息,数据库信息,表信息
- JDBC之数据库的增,删,改,查, 搜, 批量执行,获取表结构,获取某一用户下所有的表,滚轴操作的封装
- DatabaseMetaData获取数据库信息
- 【原】获取数据库(SQL SERVER 2005)的所有信息 Get all database information from SQL Server 2005 测试通过
- JDBC通过DatabaseMetaData对象了解数据库信息
- 【原】获取数据库(SQL SERVER 2005)的所有信息 Get all database information from SQL Server 2005 测试通过【想写基于数据库代码生成器可参考】
- JDBC之通过DatabaseMetaData对象了解数据库的信息
- JDBC通过DatabaseMetaData对象了解数据库信息
- jdbc之MetaData_获取数据库信息
- DatabaseMetaData获取数据库信息 .
- 1 开发一个注重性能的JDBC应用程序不是一件容易的事. 当你的代码运行很慢的时候JDBC驱动程序并不会抛出异常告诉你。 本系列的性能提示将为改善JDBC应用程序的性能介绍一些基本的指导原则,这其中的原则已经被许多现有的JDBC应用程序编译运行并验证过。 这些指导原则包括: 正确的使用数据库MetaData方法 只获取需要的数据 选用最佳性能的功能 管理连
- Atitit. 数据库-----catalog与schema的设计区别以及在实际中使用 获取数据库所有库表 java jdbc php c#.Net