Java DatabaseMetaData getCatalogs() 方法及示例


在本文中,我们将学习如何使用 Java 的 JDBC(Java 数据库连接)API 来检索和显示MySQL 实例中可用目录(数据库)的列表。通过运行连接到 MySQL 服务器的 Java 程序,我们将使用DatabaseMetaData 类getCatalogs() 方法来获取目录名称,并在控制台上显示每个目录的名称。此过程演示了如何使用 JDBC 访问和浏览 MySQL 中的元数据,从而深入了解数据库环境的结构。

检索数据库目录的步骤

getCatalogs() 方法是 DatabaseMetaData 接口的方法,它以字符串格式返回底层数据库的名称。

要获取实例中数据库的目录列表:

  • 确保您的数据库正在运行。

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

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

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

  • 最后,使用DatabaseMetaData 接口getCatalogs() 方法获取数据库目录。

创建示例数据库

让我们使用下面的 CREATE 语句在 MySQL 中创建 6 个数据库:

Create database mydatabase;
Create database exampledatabase;
Create database sampledb;
Create database students;
Create database testdb;
Create database details;

检索数据库目录的 Java 程序

下面的 JDBC 程序建立与 MySQL 数据库的连接,并检索和显示实例中数据库的目录列表:

import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
public class DatabaseMetaData_getCatalogs {
   public static void main(String args[]) throws SQLException {
      //Registering the Driver
      DriverManager.registerDriver(new com.mysql.jdbc.Driver());
      //Getting the connection
      String mysqlUrl = "jdbc:mysql://127.0.0.1/mydatabase";
      Connection con = DriverManager.getConnection(mysqlUrl, "root", "password");
      System.out.println("Connection established......");
      //Retrieving the meta data object
      DatabaseMetaData metaData = con.getMetaData();
      //Returns the name of the database
      ResultSet rs = metaData.getCatalogs();
      System.out.println("List of the catalogs in the database");
      while(rs.next()) {
         System.out.println(rs.getString(1));
      }
   }
}

输出

Connection established......
List of the catalogs in the database
information_schema
details
exampledatabase
mydatabase
mysql
performance_schema
sampledb
students
sys
testdb

代码解释

这个 Java 程序使用JDBC连接到MySQL 数据库,检索可用的数据库目录列表并打印它们。首先,我们注册 MySQL 驱动程序并使用DriverManager.getConnection()建立连接。然后,我们使用getMetaData() 方法获取 DatabaseMetaData 对象,该对象提供有关数据库的元数据。使用metaData.getCatalogs(),我们检索并循环遍历目录列表,将每个目录名称打印到控制台。这将显示当前在 MySQL 实例中可用的所有数据库。

更新于:2024年11月14日

624 次浏览

启动你的职业生涯

完成课程获得认证

开始学习
广告