Java DatabaseMetaData getTables()方法与示例

此方法检索指定数据库/目录中可用表的描述。它接受4个参数-

  • catalog-  字符串参数,代表表(通常是数据库)的名称(或名称模式),表(其中包含您需要检索其描述的列)存在于其中。传递“”以获取没有目录的表中列的描述,如果不想使用目录,则传递null,从而缩小搜索范围。

  • schemaPattern- 一个String参数,表示表的模式名称(或名称模式),如果表中的列没有模式,则传递“”,如果您不想使用模式,则传递null。

  • tableNamePattern- 一个String参数,代表表的名称(或名称模式)。

  • types-一个String参数,表示列的名称(或名称模式)。

此方法返回一个ResultSet对象,该对象描述指定目录中的表。该对象保存以下详细信息的值(作为列名)-

栏名
数据类型
描述
TABLE_CAT
String表的目录。
TABLE_SCHEM
String模式的目录。
TABLE_NAME
String表名。
TABLE_TYPE
String表的类型。(表,视图,系统表,全局表,别名,同义词等。)
REMARKSString在该列上的注释。
TYPE_SCHEM
String表的架构。
TYPE_NAME
String类型名称。
SELF_REFERENCING_COL_NAME
String表中指定列的名称。
REF_GENERATION
StringSYSTEM或USER或DERIVED。

获取数据库中所需表的描述-

  • 确保您的数据库已启动并正在运行。

  • 使用DriverManager类的registerDriver()方法注册驱动程序。传递与基础数据库相对应的驱动程序类的对象。

  • 使用DriverManager类的getConnection()方法获取连接对象。将URL和数据库中的用户密码作为字符串变量传递给数据库。

  • 使用Connection接口的getMetaData()方法获取有关当前连接的DatabaseMetaData对象。

  • 最后,通过调用DatabaseMetaData接口的getTables()方法,获得保存表说明的ResultSet对象。

示例

让我们创建一个名称为sample_database的数据库,并使用CREATE语句在其中创建一个表sample_table,如下所示-

CREATE DATABASE example_database;
CREATE TABLE example_database.sample_table(Name VARCHAR(255), age INT, Location VARCHAR(255));

现在,我们将使用INSERT语句在sample_table表中插入2条记录-

insert INTO example_database.sample_table values('Kasyap', 29, 'Vishakhapatnam');
INSERT INTO example_database.sample_table values('Krishna', 30, 'Hyderabad');

以下JDBC程序建立与MySQL数据库的连接,并检索上面创建的名为sample_table的表的描述。

import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
public class DatabaseMetaData_getTables {
   public static void main(String args[]) throws SQLException {
      //注册驱动程序
      DriverManager.registerDriver(new com.mysql.jdbc.Driver());
      //获得连接
      String url = "jdbc:mysql://localhost/example_database";
      Connection con = DriverManager.getConnection(url, "root", "password");
      System.out.println("Connection established......");
      //检索元数据对象
      DatabaseMetaData metaData = con.getMetaData();
      //检索数据库中的列
      ResultSet tables = metaData.getTables(null, null, "sample_table", null);
      //打印列名称和大小
      while (tables.next()) {
         System.out.println("Table name: "+tables.getString("Table_NAME"));
         System.out.println("Table type: "+tables.getString("TABLE_TYPE"));
         System.out.println("Table schema: "+tables.getString("TABLE_SCHEM"));
         System.out.println("Table catalog: "+tables.getString("TABLE_CAT"));
         System.out.println(" ");
      }
   }
}

输出结果

Connection established......
Table name: sample_table
Table type: TABLE
Table schema: null
Table catalog: example_database
猜你喜欢