java 手动加载数据库驱动_java 加载数据库驱动

JDBC编程步骤见

JDBC编程的第一步是加载数据库驱动,使用Class类的forName()方法,Class.forName("com.mysql.jdbc.Driver")。

//加载MySQL驱动

Class.forName("com.mysql.jdbc.Driver");//获取数据库连接

Connection conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/crashcourse", "root", "123456");

比较令人疑惑的是,它是如何加载驱动的,后续的DriverManager又是如何利用该驱动的。

打开Driver源码,可以看到如下的内容

/***

*

* When a Driver class is loaded, it should create an instance of itself and register it with the DriverManager.

* This means that a user can load and register a

* driver by doing Class.forName("foo.bah.Driver")*/

源码中的静态代码块:

static{try{

java.sql.DriverManager.registerDriver(newDriver());

}catch(SQLException E) {throw new RuntimeException("Can‘t register driver!");

}

}

由此可知,Class.forName("com.mysql.jdbc.Driver"),加载Driver类且静态初始化该类时,会创建Driver对象,并由DriverManager进行register。

mark

原文:https://www.cnblogs.com/deltadeblog/p/9405236.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值