【Java ORM思想】手写Sxt ORM框架 笔记

别说谁变了你拦得住时间么 提交于 2019-11-27 03:43:50

Connections.getTables() 方法

Retrieves a description of the tables available in the given catalog.Only table descriptions matching the catalog, schema, tablename and type criteria are returned. They are ordered by TABLE_TYPE, TABLE_CAT, TABLE_SCHEM and TABLE_NAME.
Each table description has the following columns:
1.TABLE_CAT String => table catalog (may be null)
2.TABLE_SCHEM String => table schema (may be null)
3.TABLE_NAME String => table name
4.TABLE_TYPE String => table type. Typical types are “TABLE”,“VIEW”, “SYSTEM TABLE”, “GLOBAL TEMPORARY”,“LOCAL TEMPORARY”, “ALIAS”, “SYNONYM”.
5.REMARKS String => explanatory comment on the table (may be null)
6.TYPE_CAT String => the types catalog (may be null)
7.TYPE_SCHEM String => the types schema (may be null)
8.TYPE_NAME String => type name (may be null)
9.SELF_REFERENCING_COL_NAME String => name of the designated"identifier" column of a typed table (may be null)
10.REF_GENERATION String => specifies how values inSELF_REFERENCING_COL_NAME are created. Values are"SYSTEM", “USER”, “DERIVED”. (may be null)

在这里插入图片描述
我总觉得这里的顺序给的有问题呢?
在这里插入图片描述

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

Connection接口中提供了DatabaseMetaData接口:

提供:getTables()方法,该方法需要传进4个参数:
TABLE_TYPE, TABLE_CAT, TABLE_SCHEM and TABLE_NAME

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

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

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

第四个是类型标准,以数组形式传值,有"TABLE"、“VIEW”、“SYSTEM TABLE”、“GLOBAL TEMPORARY”、“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则大小写俱可,不过我建议是全部使用大写,这里只是示例······

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!