java连接数据库时加载驱动程序Class.forName(driveName)详解
小弟刚刚转向java,在连接数据库的时候,以前都是死记整个连接过程的,并不知道各个语句真正的作用,今天闲来无事,看了看源代码,将个人理解列出,希望各位指出不足和错误之处。
连接数据库,一般都是这样一个过程:
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; } }}/ * 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() }}
public static void registerDriver(Driver driver)
throws SQLException
向 DriverManager 注册给定驱动程序。新加载的驱动程序类应该调用 registerDriver 方法让 DriverManager 知道自己。
参数:
driver- 将向 DriverManager 注册的新的 JDBC Driver
抛出:SQLException- 如果发生数据库访问错误
新加载的驱动程序类应该调用 registerDriver 方法让 DriverManager 知道自己。 这一句是不是就让Driver类中的
java.sql.DriverManager.registerDriver(new Driver());
理所当然了呢。
好了,注册完驱动程序之后,我们就可以通过调用DriverManager的其他方法进行数据库的操作了.
以上就是小弟的个人理解了,请批评指正。
[解决办法]
不错,对新手来说还是很有帮助的,攒一个