博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用JDBC时 Class.forName()的作用
阅读量:4031 次
发布时间:2019-05-24

本文共 2195 字,大约阅读时间需要 7 分钟。

转自http://dustin.javaeye.com/blog/44291

使用JDBC时,我们都会很自然得使用下列语句:

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

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

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.   * Construct a new driver and register it with DriverManager  
  19.   *   
  20.   * @throws SQLException  
  21.   *             if a database error occurs.  
  22.   */   
  23.   public  Driver()  throws  SQLException {   
  24.       // Required for Class.forName().newInstance()   
  25.  }   
  26. }  

转载地址:http://jaqbi.baihongyu.com/

你可能感兴趣的文章
final 的作用
查看>>
在Idea中使用Eclipse编译器
查看>>
idea讲web项目部署到tomcat,热部署
查看>>
优化IDEA启动速度,快了好多。后面有什么优化点,会继续往里面添加
查看>>
JMeter 保持sessionId
查看>>
IDEA Properties中文unicode转码问题
查看>>
Idea下安装Lombok插件
查看>>
zookeeper
查看>>
Idea导入的工程看不到src等代码
查看>>
技术栈
查看>>
Jenkins中shell-script执行报错sh: line 2: npm: command not found
查看>>
8.X版本的node打包时,gulp命令报错 require.extensions.hasownproperty
查看>>
Jenkins 启动命令
查看>>
Maven项目版本继承 – 我必须指定父版本?
查看>>
Maven跳过单元测试的两种方式
查看>>
通过C++反射实现C++与任意脚本(lua、js等)的交互(二)
查看>>
利用清华镜像站解决pip超时问题
查看>>
[leetcode BY python]1两数之和
查看>>
微信小程序开发全线记录
查看>>
Centos import torchvision 出现 No module named ‘_lzma‘
查看>>