JDBC 有四种驱动类型,分别是:

  • JDBC-ODBC 桥(JDBC-ODBC bridge driver plus ODBC driver)
  • 本地 API 驱动(Native-API partly Java driver)
  • 网络协议驱动(JDBC-Net pure Java driver)
  • 本地协议驱动(Native-protocol pure Java driver)

1. JDBC-ODBC 桥

从名称之中就可以知道,这种驱动是 JDBC 在 ODBC 已有的功能上做了一层适配工作,即搭桥(Bridge)。

这种驱动完全依赖 ODBC 的实现,JDBC 只是做了一层封装工作。

JDBC-ODBC 桥最主要的功能,是支持 Java 访问 Access 这种伪关系型数据库。

JDBC-ODBC 桥最大的优点在于:ODBC 的代码在天然的在许多使用数据库的客户端上有,所以这种驱动的安装十分便捷。

但是,JDBC-ODBC 桥有以下两个主要的缺点:

  • 由于对 ODBC 的依赖,导致支持的功能有限,性能不佳,扩展能力很弱。
  • 不适合在并发访问数据库的情况下使用。

在 Java8 的实现中,已经删除了 JDBC-ODBC 桥这种驱动方式。

2. 本地 API 驱动

这种驱动方式,相当于 JDBC 完全使用了 ODBC 的工作方式。

在这种驱动中,JDBC调用转换为对 DBMS 的客户端 API 的调用。

JDBC-ODBC 桥的驱动方式,等于是对所有的数据库调用进行了一次整合;而本地 API 驱动则是绕过了 ODBC,对数据库 API 的调用进行了整合。

所以这种驱动方式的效率,相比第一种驱动,会有显著的提高。

然而,与 JDBC-ODBC 桥驱动相同,对客户端数据库的 API 有依赖,所以也不适合基于 Internet 的应用。

3. 网络协议驱动

这种驱动方式,适用于基于 Internet 的应用,它依赖于一个网络服务器上的中间产品:

  • 首先,将 JDBC 调用转化为一个 DBMS 无关的网络协议,传递给中间服务器。
  • 然后,中间服务器负责将这种请求,转化为符合相应的数据库规范的请求,转发给数据库服务器。

这种驱动是基于 Server 端的,所以不需要在客户端加载数据库厂商的代码库。

它在在执行效率,可升级性,灵活性方面都很好。

这种驱动,设计的代码量很小,可以很快地加载到内存当中。

但是,这种驱动在中间件层仍然需要有配置其它数据库驱动程序,而且增加了一个中间层去传递数据,执行效率还不是最好。

同时,基于 Internet 的访问要求,客户端必须处理 Web 所提出的安全性、通过防火墙的访问等方面的额外要求。

4. 本地协议驱动

这种驱动程序将 JDBC 调用直接转换为 DBMS 使用的网络协议。

这种驱动允许从客户端机器直接调用 DBMS 服务器,是内部网(Intranet)访问的优秀解决方案。

由于许多这样的协议都是专用的,因此数据库提供者自己将是主要来源。

5. 总结

  • JDBC-ODBC 桥,适合作为开发应用时的一种过度方案,不使用大量的数据库操作。
  • 本地 API 驱动,只适用于内部网,但是执行效率不高,所以一般也不采用。
  • 网络协议驱动,适用于需要同时连接多个不同种类的数据库的应用。
  • 本地协议驱动,适合于连接单一数据库的应用。

从执行效率来讲,第3、4型的驱动是首选,平时通过加载一个 jar 包来达到连接数据库目的的,是第4型驱动。

JDBC 学习笔记(二)—— 详解 JDBC 的四种驱动类型的更多相关文章

  1. JDBC学习1:详解JDBC使用

    什么是JDBC JDBC(Java Database Connectivity),即Java数据库连接,是一种用于执行SQL语句的Java API,可以为多种关系数据库提供同一访问,它由一组用Java ...

  2. JDBC学习笔记二

    JDBC学习笔记二 4.execute()方法执行SQL语句 execute几乎可以执行任何SQL语句,当execute执行过SQL语句之后会返回一个布尔类型的值,代表是否返回了ResultSet对象 ...

  3. JDBC 学习笔记(十一)—— JDBC 的事务支持

    1. 事务 在关系型数据库中,有一个很重要的概念,叫做事务(Transaction).它具有 ACID 四个特性: A(Atomicity):原子性,一个事务是一个不可分割的工作单位,事务中包括的诸操 ...

  4. JavaScript学习笔记-实例详解-类(二)

    实例详解-类(二)   //===给Object.prototype添加只读\不可枚举\不可配置的属性objectId(function(){ Object.defineProperty(Object ...

  5. Angular6 学习笔记——组件详解之组件通讯

    angular6.x系列的学习笔记记录,仍在不断完善中,学习地址: https://www.angular.cn/guide/template-syntax http://www.ngfans.net ...

  6. Angular6 学习笔记——组件详解之模板语法

    angular6.x系列的学习笔记记录,仍在不断完善中,学习地址: https://www.angular.cn/guide/template-syntax http://www.ngfans.net ...

  7. Angular6 学习笔记——路由详解

    angular6.x系列的学习笔记记录,仍在不断完善中,学习地址: https://www.angular.cn/guide/template-syntax http://www.ngfans.net ...

  8. JavaScript学习笔记-实例详解-类(一)

    实例详解-类(一): //每个javascript函数(除了bind())都自动拥有一个prototype对象// 在未添加属性或重写prototype对象之前,它只包含唯一一个不可枚举属性const ...

  9. Android学习笔记-Dialog详解

    1.对话框的使用 1.1AlertDialog的显示 简单对话框以及监听的设置:重点掌握三个按钮(也就是三上单词): PositiveButton(确认按钮);NeutralButton(忽略按钮) ...

随机推荐

  1. C++ 值传递&引用&地址

  2. 【胎教】做AI的基础,开始学习。

    昨天,找了博导,他给我聊了一下暑假任务.现总结如下: 1. 周志华, 机器学习: 2. GoodFellow,深度学习: 3. 曾更生,*****医学图像处理: 4. cs231n,公式推导,课后习题 ...

  3. eubacteria|endosymbiosis|基因转移

    5.11线粒体和叶绿体是通过内共生进化而来的 初始细胞俘获有功能的真细菌(eubacteria)进入细胞内,该细菌逐渐演化为细胞器,这种现象称为内共生(endosymbiosis),所以该细胞器携带细 ...

  4. 01_1_准备ibatis环境

    01_1_准备ibatis环境 1. 搭建环境:导入相关的jar包 mysql-connector-java-5.1.5-bin.jar(mysql)或者ojdbc6.jar(oracle).ibat ...

  5. Spring中使用事务搭建转账环境方法二 相对简便的注解方法 ——配置文件注入对象属性需要setter方法 注解方法,不需要生成setter方法

    XML配置文件代码如下: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=" ...

  6. iOS应用架构谈part3 网络层设计方案

    前言 网络层在一个App中也是一个不可缺少的部分,工程师们在网络层能够发挥的空间也比较大.另外,苹果对网络请求部分已经做了很好的封装,业界的AFNetworking也被广泛使用.其它的ASIHttpR ...

  7. C++系统学习之九:顺序容器

    元素在顺序容器中的顺序与其加入容器时的位置相对应.关联容器中元素的位置由元素相关联的关键字值决定.所有容器类都共享公共的接口,不同容器按不同方式对其进行扩展. 一个容器就是一些特定类型对象的集合.顺序 ...

  8. [CF] 180 E. Cubes

    对同类元素双指针扫描 #include<iostream> #include<cstring> #include<cstdio> #include<vecto ...

  9. pythonnet-网络编程(1)

    python的网络编程有不少难点,也容易忘记,最近我会陆续发出系统.完整pythonnet知识的博客,一边复习一边分享,感兴趣的可以关注我. 话不多说,开始吧. 网络编程 目的:数据的传输 ISO(国 ...

  10. Java-JFrame-swing嵌套浏览器步骤

    Java-JFrame-swing嵌套浏览器步骤 一.使用swing嵌套浏览器要实现的功能: 通过java的swing实现在一个窗体中嵌套一个浏览器,可以在这个浏览器中将另一个项目的内容显示出来,只需 ...