gpt4 book ai didi

java - 连接到数据库时 Class.forName ("oracle.jdbc.driver.OracleDriver"的实际用途是什么?

转载 作者:IT老高 更新时间:2023-10-28 11:38:40 25 4
gpt4 key购买 nike

命令是什么

Class.forName("oracle.jdbc.driver.OracleDriver")

在连接到 Oracle 数据库时确实如此吗?有没有其他方法可以做同样的事情?

最佳答案

它使用 FQCN(完全限定的类名)oracle.jdbc.driver.OracleDriver获取对类对象的引用。

除了确保指定的类由当前的类加载器加载之外,它在连接到数据库方面没有“做”任何事情。写法没有本质区别

Class<?> driverClass = Class.forName("oracle.jdbc.driver.OracleDriver");
// and
Class<?> stringClass = Class.forName("java.lang.String");

Class.forName("com.example.some.jdbc.driver") 调用出现在使用 JDBC 的 legacy 代码中,因为 that is the legacy way of loading a JDBC driver .

来自 The Java Tutorial :

In previous versions of JDBC, to obtain a connection, you first had to initialize your JDBC driver by calling the method Class.forName. This methods required an object of type java.sql.Driver. Each JDBC driver contains one or more classes that implements the interface java.sql.Driver.
...
Any JDBC 4.0 drivers that are found in your class path are automatically loaded. (However, you must manually load any drivers prior to JDBC 4.0 with the method Class.forName.)

进一步阅读(阅读:问题这是重复的)

关于java - 连接到数据库时 Class.forName ("oracle.jdbc.driver.OracleDriver"的实际用途是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8053095/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com