java 加载数据库驱动
Posted Delta
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java 加载数据库驱动相关的知识,希望对你有一定的参考价值。
JDBC编程步骤见 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源码,可以看到如下的内容
/** * * <p> * 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(new Driver()); } catch (SQLException E) { throw new RuntimeException("Can\'t register driver!"); } }
由此可知,Class.forName("com.mysql.jdbc.Driver"),加载Driver类且静态初始化该类时,会创建Driver对象,并由DriverManager进行register。
以上是关于java 加载数据库驱动的主要内容,如果未能解决你的问题,请参考以下文章