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 实例中可用的所有数据库。