我们在写用Java操作数据库的时候通常情况都会写这段代码进行驱动的注册:
Class.forName("com.mysql.cj.jdbc.Driver");
但我们试着把这段注册驱动的代码给注释会发生什么?
//Class.forName("com.mysql.cj.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mumangguo","root","admin");
Statement statement = conn.createStatement();
ResultSet rs = statement.executeQuery("select * from t_user");
while (rs.next()) {
System.out.println(rs.getString("username")+","+rs.getString("password"));
}
我们会发现,居然没有报错,让我们走进JDBC驱动的源代码中,我们就会发现,在注册驱动的DriverManager类上有这样的一段注释:
* <P>Applications no longer need to explicitly load JDBC drivers using <code>Class.forName()</code>. Existing programs
* which currently load JDBC drivers using <code>Class.forName()</code> will continue to work without
* modification.
这段注释翻译过来的意思也就是说:
应用程序不再需要使用 Class.forName() 显式加载 JDBC 驱动程序。当前使用 Class.forName() 加载 JDBC 驱动程序的现有程序将继续工作而无需修改。
在JDBC4.0后,我们的JDBC包中包含了一个名为java.sql.Driver的文件
JDBC4.0之后 自动扫描jar包下这个文件,理论上是不用我们主动的注册驱动,方便了我们的编程。
注意:但是经过测试在JavaWeb项目中,还是不行的,经过大量的资料搜索,我还是没找到关于这一块的解释,你们可以自己去探索探索。
总结:可以不用显式注册驱动,但是在Web项目中不行!