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:///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 次瀏覽

啟動你的職業生涯

完成課程獲得認證

開始學習
廣告
© . All rights reserved.