JDBC Driver Types
相信做过Java开发的人都对JDBC驱动有所了解:它是Java程序访问数据库的中间件。JDBC驱动可以使Java程序打开数据库连接,并发送SQL(DDL,DML)或者数据库命令,执行结果以Java数据类型返回。从实现的角度来讲:它是对Java的JDBC API的实现,由第三方数据库厂商来完成。
JDBC Driver Types
由于操作系统、硬件平台的多样性, Sun公司将JDBC实现分为4种类型(Type1 ,2,3,4)。下面就对这四种类型分别进行说明。
Type 1:JDBC-ODBC Bridge Driver
对于type1 类型的驱动,通信模型是这样的:
1) 一台服务器上安装有Database Server
2) 本机(运行java程序的机器)上安装数据库的客户机
- ·这个客户机程序用于和远程Database Server 通信
- ·这个客户机程序上有ODBC驱动。
3) Java程序与客户机上的ODBC驱动通信,会使用到一个JDBC ODBC桥(type 1)
也就是说,Java程序通过JDBC ODBC桥与客户机上的ODBC驱动通信,ODBC与远程数据库通信,以此来完成Java与数据库的通信。
在Java刚诞生的那个年代,这种方式是很有用的,因为当时的数据库都是只支持ODBC访问。但现在呢,这种访问方式已经很少看到了。如果你想要练习这种方式的话,还是可以的。
譬如说SQLServer、Access、DB2 ,肯定还是支持这种方式的。
Type 2:JDBC-Native API
这种方式下,JDBC API 使用了JNI方式,也就是Java调用转为C/C++调用,以此来访问数据库。也就是说整个通信过程是这样的:
·Java代码调用JDBC API
·JDBC API转为JNI调用,即Type2 类型的驱动调用。
·Type2类型的驱动访问数据库。
这种方式,也是需要安装客户机的,因为这个驱动(Type2-Native API 实现)是在客户机里才有的。
Type2相比与Type1,少了ODBC,所以这种方式的开销会更少一些。
例如,在使用PLSQL Developer时,会使用到OCI(Oracle Call Interface)。
Type 3:JDBC-Net pure Java
Type1, 2, 4都是一种两层的通信模式:本机程序(包括Java程序、驱动、客户机)->数据库服务器。然而Type 3则是一种三层的通信模式:
中间服务器上安装了JDBC Type1,2,4类型的驱动与远程数据库直接交互,java程序使用Type3驱动基于网络来调用JDBC Type1,2,4,以此来完成Java程序与数据库的通信。
Type 4:100% Pure Java
这种方式,应该是目前最为常用的了。直接通过JDBC驱动与数据库进行交互。还需要安装客户机什么的。
官方文档中的通信模型图
如何选择JDBC驱动呢?
如果你访问一类数据库,例如Oracle, Sybase, IBM,最好是选用type 4.
如果你的Java程序会同时访问多种数据库,Type 3 是不错的选择。
如果Type3,4都不可用的情况下,Type2 是一种不错的选择。
Type 1 现在已很少用的到了。
JDBC Driver Types的更多相关文章
- ORACLE11g JDBC Driver
http://blog.163.com/z_rx/blog/static/276363762011312947507/ ORACLE服务器端安装程序找到相应目录"x$\app\Adminis ...
- Using the JDBC Driver
Download JDBC Driver This section provides quick start instructions for making a simple connection t ...
- Class.forName("com.mysql.jdbc.Driver") ;
try { Class.forName("com.mysql.jdbc.Driver") ; } catch(ClassNotFoundException e) { System. ...
- [bigdata] 启动CM出现 “JDBC Driver class not found: com.mysql.jdbc.Driver” 以及“Error creating bean with name 'serverLogFetcherImpl'”问题的解决方法
问题:“JDBC Driver class not found: com.mysql.jdbc.Driver” 通过以下命令启动cm [root@hadoop1 ~]# /etc/init.d/cl ...
- java中myeclipse连接mysql问题(java.lang.ClassNotFoundException: com.mysql.jdbc.Driver)
java中myeclipse连接mysql问题(java.lang.ClassNotFoundException: com.mysql.jdbc.Driver) 1.往项目中添加mysql-conne ...
- JDBC driver connection string大全
Database / data source URL format / driver name Value Default port MySQL URL format: jdbc:mysql: ...
- java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver 错误的解决办法
java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver 错误的解决办法 (2011-05-05 16:08:05) 转载▼ ...
- unkow jdbc driver : http://maven.apache.org
报了这么一个错,找了很久才找到问题出在哪里,具体为什么会什么出现现在还不怎么懂,只是现在能让它继续跑起来 这个错是因为我的spring-mybatis.xml文件读取不了jdbc.properties ...
- 【转】关于Class.forName(“com.mysql.jdbc.Driver”)
原文:http://www.cnblogs.com/gaojing/archive/2012/03/23/2413638.html 传统的使用jdbc来访问数据库的流程为: Class.forName ...
随机推荐
- objective-c 语法快速过(5)
oc 的分类-Category 通过分类(category)可以以模块的方式向现有的类添加方法. 它提供了一种简单的方式, 用它可以将类的定义模块化到相关方法的组或分类中.它还提供了扩展现有类定义的简 ...
- Anliven - 一碗毒鸡汤
什么是你的核心动力,支撑着你持续前进? 什么是你的加速度,激发你全部的潜能和勇气? 你的核心动力应该来自于: 家人与朋友的信任.包容与期待 你本应承担的责任 对自己有所要求,有所期待,你本应更好 而你 ...
- 解析Exception和C#处理Exception的常用方法总结
在.NET中,异常是指成员没有完成它的名称宣称可以完成的行动.在异常的机制中,异常和某件事情的发生频率无关. 异常处理四要素包括:一个表示异常详细信息的类类型:一个向调用者引发异常类实例的成员:调用者 ...
- SIFT特征详解
1.SIFT概述 SIFT的全称是Scale Invariant Feature Transform,尺度不变特征变换,由加拿大教授David G.Lowe提出的.SIFT特征对旋转.尺度缩放.亮度变 ...
- OpenGL超级宝典visual studio 2013开发环境配置,GLTools
做三维重建需要用到OpenGL,开始看<OpenGL超级宝典>,新手第一步配置环境就折腾了一天,记录下环境的配置过程. <超级宝典>中的例子使用了GLEW,freeglut以及 ...
- 【Android】Fragment懒加载和ViewPager的坑
效果 老规矩,先来看看效果 ANDROID和福利两个Fragment是设置的Fragment可见时加载数据,也就是懒加载.圆形的旋转加载图标只有一个,所以,如果当前Fragment正处于加载状态,在离 ...
- Rafy 领域实体框架演示(4) - 使用本地文件型数据库 SQLCE 绿色部署
本系列演示如何使用 Rafy 领域实体框架快速转换一个传统的三层应用程序,并展示转换完成后,Rafy 带来的新功能. <福利到!Rafy(原OEA)领域实体框架 2.22.2067 发布!> ...
- 背水一战 Windows 10 (17) - 动画: ThemeTransition(过渡效果)
[源码下载] 背水一战 Windows 10 (17) - 动画: ThemeTransition(过渡效果) 作者:webabcd 介绍背水一战 Windows 10 之 动画 ThemeTrans ...
- 连接输出 如果存在在php中多次echo输出js的时候
- java中抽象、分装、继承和多态的理解
1.抽象.封装装.继承和多态是java面向对象编程的几大特点. 抽象:所谓抽象就是对某件事务,我们忽略我们不关心不需要的部分,提取我们想要的属性和行为,并且以代码的形式提现出来:例如我们需要对一个学生 ...