JDBC4.0不用显式注册驱动了?

我们在写用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项目中不行!

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

木芒果呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值