jdbc连接问题 Class.forName("com.mysql.jdbc.Driver");的作用

Class.forName("com.mysql.jdbc.Driver");的作用
使用JDBC时,我们都会很自然得使用下列语句:
1. Class.forName("com.mysql.jdbc.Driver");
2. Connection con=DriverManager.getConnection("jdbc:mysql://localhost:3306/test","root","jb123456");
3. Statement st=con.createStatement();
或者这样的语句:
1. Class.forName("com.mysql.jdbc.Driver");   
2. String url="jdbc:mysql://localhost:3306/test";   
3. String user="root";   
4. String psw="jb123456";   
5. Connection con=DriverManager.getConnection(url,user,psw); 

下面我详细讲解一下上面语句的作用:
Statement st=con.createStatement(); 意思是:创建一个 Statement 对象来将 SQL 语句发送到数据库。不带参数的 SQL 语句通常使用 Statement 对象执行。如果多次执行相同的 SQL 语句,使用 PreparedStatement 对象可能更有效。
使用返回的 Statement 对象创建的结果集在默认情况下类型为 TYPE_FORWARD_ONLY,并带有 CONCUR_READ_ONLY 并发级别。已创建结果集的可保存性可调用 getHoldability() 确定。


为什么说很自然呢,因为无论是网上还是书本教程上得例子都是这样的,而且程序也确实正常运行了,于是大家也就心安理得的找葫芦画瓢下去了。
    一定要有这一句吗?不是的,我们完全可以用这样一句代替它:

java 代码
  1. com.mysql.jdbc.Driver driver = new com.mysql.jdbc.Driver();   
  2. //or:   
  3. //new com.mysql.jdbc.Driver();   
  4. String url = "jdbc:mysql://127.0.0.1/test?useUnicode=true&characterEncoding=utf-8";   
  5. String user = "";   
  6. String psw = "";   
  7. Connection con = DriverManager.getConnection(url,user,psw);   
  8.   

    大家可能都看出个大概来了,我们只需要在调用DriverManager的getConnection方法之前,保证相应的Driver类已经被加载到 jvm中,并且完成了类的初始化工作就行了,而具体是怎样实现这个功能却是没有讲究的。上面两种方法都可以实现这个功能,因此程序可以正常运行。注意了, 如果我们进行如下操作,程序是不能正常运行的,因为这样仅仅使Driver类被装载到jvm中,却没有进行相应的初始化工作。

java 代码
  1. com.mysql.jdbc.Driver driver = null;   
  2. //or:   
  3. ClassLoader cl = new ClassLoader();   
  4. cl.loadClass("com.mysql.jdbc.Driver");  


     我们都知道JDBC是使用Bridge模式进行设计的,DriverManager就是其中的Abstraction,java.sql.Driver是 Implementor,com.mysql.jdbc.Driver是Implementor的一个具体实现(请参考GOF的Bridge模式的描 述)。大家注意了,前一个Driver是一个接口,后者却是一个类,它实现了前面的Driver接口。
     Bridge模式中,Abstraction(DriverManager)是要拥有一个Implementor(Driver)的引用的,但是我们在使 用过程中,并没有将Driver对象注册到DriverManager中去啊,这是怎么回事呢?jdk文档对Driver的描述中有这么一句:
     When a Driver class is loaded, it should create an instance of itself and register it with the DriverManager
哦,原来是com.mysql.jdbc.Driver在装载完后自动帮我们完成了这一步骤。源代码是这样的:

java 代码
  1. package com.mysql.jdbc   
  2.   
  3. public class Driver extends NonRegisteringDriver implements java.sql.Driver {   
  4. // ~ Static fields/initializers   
  5. // --------------------------------------------- //   
  6. // Register ourselves with the DriverManager   
  7. //   
  8. static {   
  9.      t ry {   
  10.                java.sql.DriverManager.registerDriver(new Driver());   
  11.            } catch (SQLException E) {   
  12.               throw new RuntimeException("Can't register driver!");   
  13.            }   
  14.    }   
  15. // ~ Constructors   
  16. // -----------------------------------------------------------   
  17.   
  18. public Driver() throws SQLException {   
  19.      // Required for Class.forName().newInstance()   
  20. }   
  21. }  

你可能感兴趣的:(java,jdbc)