如何使用 JDBC 获取使用 DriverManager 注册的所有驱动程序的列表?

jdbcobject oriented programmingprogramming

java.sql.DriverManager 类管理应用程序中的 JDBC 驱动程序。此类维护所需驱动程序的列表,并在初始化时加载它们。

因此,您需要在使用驱动程序类之前注册它。但是,每个应用程序只需执行一次。

将驱动程序类对象注册到驱动程序管理器的一种方法是 DriverManager 类的 registerDriver() 方法。您需要将 Driver 对象作为参数传递给此方法。

//实例化驱动程序类 Driver driver = new com.mysql.jdbc.Driver();
//注册驱动程序 DriverManager.registerDriver(driver);

所有驱动程序的列表

您可以使用该 DriverManager 类的 getDrivers() 方法获取已注册到该类的所有驱动程序的列表。此方法返回一个包含驱动程序列表的枚举。

//检索所有驱动程序的列表
Enumeration<Driver> e = DriverManager.getDrivers();
//打印列表
while(e.hasMoreElements()) {
   System.out.println(e.nextElement().getClass());
}

以下 JDBC 程序使用 registerDriver() 方法注册了一组 JDBC 驱动程序,并使用 getDrivers() 方法显示它们的列表。

示例

import java.sql.Driver;
import java.sql.DriverManager;
import java.util.Enumeration;
public class DriversList_DriverManager {
   public static void main(String args[])throws Exception {
      //注册 MySQL 驱动程序
      DriverManager.registerDriver(new com.mysql.jdbc.Driver());
      //注册 SQLite 驱动程序
      DriverManager.registerDriver(new org.sqlite.JDBC());
      //注册 Oracle 驱动程序
      DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
      //注册 Derby 客户端驱动程序
      DriverManager.registerDriver(new org.apache.derby.jdbc.ClientDriver());
      //注册 Derby 自动加载驱动程序
      DriverManager.registerDriver(new org.apache.derby.jdbc.AutoloadedDriver());
      //注册 HSQLDb-JDBC 驱动程序
      DriverManager.registerDriver(new org.hsqldb.jdbc.JDBCDriver());
      System.out.println("使用 DriverManager 注册的所有驱动程序的列表:");
      //检索所有驱动程序的列表
      Enumeration<Driver> e = DriverManager.getDrivers();
      //打印列表
      while(e.hasMoreElements()) {
         System.out.println(e.nextElement().getClass());
      }
      System.out.println();
   }
}

输出

List of all the Drivers registered with the DriverManager:
class org.sqlite.JDBC
class org.apache.derby.jdbc.ClientDriver
class org.apache.derby.jdbc.AutoloadedDriver
class org.hsqldb.jdbc.JDBCDriver
class com.mysql.jdbc.Driver
class oracle.jdbc.driver.OracleDriver

相关文章