如何使用JDBC获取已注册到DriverManager的所有驱动程序列表?
java.sql.DriverManager 类管理应用程序中的 JDBC 驱动程序。此类维护所需驱动程序的列表,并在初始化时加载它们。
因此,您需要在使用驱动程序类之前注册它。但是,您只需要对每个应用程序执行一次此操作。
将驱动程序类对象注册到驱动程序管理器的一种方法是使用DriverManager类的registerDriver()方法。此方法需要您将 Driver 对象作为参数传递。
//Instantiating a driver class Driver driver = new com.mysql.jdbc.Driver(); //Registering the Driver DriverManager.registerDriver(driver);
所有驱动程序的列表
您可以使用DriverManager类的getDrivers()方法获取已注册到此DriverManager类中的所有驱动程序的列表。此方法返回一个包含驱动程序列表的 Enumeration。
//Retrieving the list of all the Drivers
Enumeration<Driver> e = DriverManager.getDrivers();
//Printing the list
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 {
//Registering MySQL driver
DriverManager.registerDriver(new com.mysql.jdbc.Driver());
//Registering SQLite driver
DriverManager.registerDriver(new org.sqlite.JDBC());
//Registering Oracle driver
DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
//Registering Derby-client driver
DriverManager.registerDriver(new org.apache.derby.jdbc.ClientDriver());
//Registering Derby-autoloaded driver
DriverManager.registerDriver(new org.apache.derby.jdbc.AutoloadedDriver());
//Registering HSQLDb-JDBC driver
DriverManager.registerDriver(new org.hsqldb.jdbc.JDBCDriver());
System.out.println("List of all the Drivers registered with the DriverManager:");
//Retrieving the list of all the Drivers
Enumeration<Driver> e = DriverManager.getDrivers();
//Printing the list
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
广告
数据结构
网络
关系数据库管理系统 (RDBMS)
操作系统
Java
iOS
HTML
CSS
Android
Python
C语言编程
C++
C#
MongoDB
MySQL
Javascript
PHP