是否需要Class.forName()机制?
以下代码:
Class.forName(dbDriver); // "org.postgres.Driver" or "com.mysql.jdbc.Driver"
是/是打开JDBC连接所必需的。
我听说现代JDBC驱动程序不再需要它。但是我无法在项目中将其删除,因为我遇到了No suitable driver
found异常。我正在使用postgresql-9.1-901.jdbc3.jar
Java7和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