是否需要Class.forName()机制?

以下代码:

Class.forName(dbDriver); // "org.postgres.Driver" or "com.mysql.jdbc.Driver"

是/是打开JDBC连接所必需的。

我听说现代JDBC驱动程序不再需要它。但是我无法在项目中将其删除,因为我遇到了No suitable driver

found异常。我正在使用postgresql-9.1-901.jdbc3.jarJava7和tomcat7。

什么时候可以省略Class.forName(...)构建?

回答:

从JDBC 4.0开始,不需要Class.forName()。

这是JDBC的Java教程的摘录。

早期 ,要获得连接,首先必须通过调用方法Class.forName初始化JDBC驱动程序。此方法需要一个java.sql.Driver类型的对象。每个JDBC驱动程序包含一个或多个实现接口java.sql.Driver的类。Java

DB的驱动程序是org.apache.derby.jdbc.EmbeddedDriver和org.apache.derby.jdbc.ClientDriver,而MySQLConnector / J的驱动程序是com.mysql.jdbc.Driver。请参阅DBMS驱动程序的文档以获取实现接口java.sql.Driver的类的名称。

(但是,必须使用Class.forName方法手动加载JDBC4.0之前的所有驱动程序。)

以上是 是否需要Class.forName()机制? 的全部内容, 来源链接: utcz.com/qa/400264.html

回到顶部