当前位置: 代码迷 >> J2SE >> java连接数据库时加载驱动程序Class.forName(driveName)详解,该怎么处理
  详细解决方案

java连接数据库时加载驱动程序Class.forName(driveName)详解,该怎么处理

热度:1810   发布时间:2013-02-25 00:00:00.0
java连接数据库时加载驱动程序Class.forName(driveName)详解
小弟刚刚转向java,在连接数据库的时候,以前都是死记整个连接过程的,并不知道各个语句真正的作用,今天闲来无事,看了看源代码,将个人理解列出,希望各位指出不足和错误之处。

连接数据库,一般都是这样一个过程:
Java code
package lin.test;import java.sql.*;public class Test{    public static void main(String[] args)    {        //驱动程序名        String driveName = "com.mysql.jdbc.Driver";        //URL指向要访问的数据库名test        String databaseURL = "jdbc:mysql://localhost:3306/test";        //MySQL配置时的用户名        String user = "root";                //MySQL配置时的密码        String password = "root";// 此处写自己的密码        try        {                        //加载驱动            Class.forName(driveName);            System.out.println("成功加载数据库驱动程序");        }        catch (java.lang.ClassNotFoundException e)        {            System.out.println("加载数据库驱动程序失败");            System.out.println("加载数据库驱动程序失败");            System.out.println(e.getMessage());            return;        }        try        {                         /连续MySQL数据库            Connection con = DriverManager.getConnection(databaseURL, user,password);            System.out.println("连接数据库成功");            //关闭连接            con.close();        }        catch (SQLException e)        {            System.out.println("连接数据库失败");            System.out.println("SQLException:" + e.getMessage());            return;        }    }}


代码中Class.forName(driveName);一直困扰我,书上的解释就是它就是加载驱动程序的,那么,它究竟是怎么加载的呢?
首先,我们来看看Class.forName()方法究竟是干什么的?
JDK API 中的解释是这样的:
public static Class<?> forName(String className)
  throws ClassNotFoundException
  返回与带有给定字符串名的类或接口相关联的 Class 对象。调用此方法等效于: 
  Class.forName(className, true, currentLoader)
其中 currentLoader 表示当前类的定义类加载器。 
例如,以下代码片段返回命名为 java.lang.Thread 的类的运行时 Class 描述符。
  Class t = Class.forName("java.lang.Thread")
调用 forName("X") 将导致命名为 X 的类被初始化。
参数:
  className- 所需类的完全限定名。
返回:
  具有指定名的类的 Class 对象。
抛出:
  LinkageError- 如果链接失败
  ExceptionInInitializerError- 如果此方法所激发的初始化失败
  ClassNotFoundException- 如果无法定位该类

所以Class.forName(driveName);即Class.for("com.mysql.jdbc.Driver"),它返回了一个Driver对象。
那么,这句代码的意思就是返回一个Driver对象,跟加载驱动程序有什么关系呢?(小弟当时也纳闷啊)。
后来翻看了一下Driver类的源代码,才恍然大悟:
Driver类的源代码如下:
Java code
/ * 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") */package com.mysql.jdbc;import java.sql.SQLException;public class Driver extends NonRegisteringDriver implements java.sql.Driver {    // ~ Static fields/initializers    // ---------------------------------------------    //    // Register ourselves with the DriverManager    //    static {        try {            java.sql.DriverManager.registerDriver(new Driver());        } catch (SQLException E) {            throw new RuntimeException("Can't register driver!");        }    }    // ~ Constructors    // -----------------------------------------------------------    /**     * Construct a new driver and register it with DriverManager     *      * @throws SQLException     *             if a database error occurs.     */    public Driver() throws SQLException {        // Required for Class.forName().newInstance()    }}


在返回Driver类对象的时候,首先执行的是static静态代码快里的内容,通过执行
java.sql.DriverManager.registerDriver(new Driver());
来注册驱动程序的。
我们再来看看JDK API中对registerDriver方法的解释
  相关解决方案