JDBC驱动程序分类

  • JDBC驱动程序:各个数据库厂商根据JDBC的规范制作的 JDBC 实现类的类库
  • JDBC驱动程序总共有四种类型:
    •   第一类:JDBC-ODBC桥。
    •   第二类:部分本地API部分Java的驱动程序。
    •   第三类:JDBC网络纯Java驱动程序。
    •   第四类:本地协议的纯 Java 驱动程序。
    •   第三、四两类都是纯Java的驱动程序,因此,对于Java开发者来说,它们在性能、可移植性、功能等方面都有优势。

ODBC

  • 早期对数据库的访问,都是调用数据库厂商提供的专有的 API。为了在 Windows 平台下提供统一的访问方式,微软推出了 ODBC(Open Database Connectivity,开放式数据库连接),并提供了 ODBC API,使用者在程序中只需要调用 ODBC API,由 ODBC 驱动程序将调用转换成为对特定的数据库的调用请求
  • 一个基于ODBC的应用程序对数据库的操作不依赖任何DBMS(database manager system),不直接与DBMS打交道,所有的数据库操作由对应的DBMS的ODBC驱动程序完成。也就是说,不论是FoxPro、Access , MYSQL还是Oracle数据库,均可用ODBC API进行访问。由此可见,ODBC的最大优点是能以统一的方式处理所有的数据库

JDBC-ODBC桥

  • JDBC-ODBC 桥本身也是一个驱动,利用这个驱动,可以使用 JDBC-API 通过ODBC 去访问数据库。这种机制实际上是把标准的 JDBC 调用转换成相应的 ODBC 调用,并通过 ODBC 访问数据库
  • 因为需要通过多层调用,所以利用 JDBC-ODBC 桥访问数据库的效率较低
  • 在 JDK 中,提供了 JDBC-ODBC 桥的实现类(sun.jdbc.odbc.JdbcOdbcDriver)

部分本地API部分Java的驱动程序

  • 这种类型的 JDBC 驱动程序使用 Java 编写,它调用数据库厂商提供的本地 API
  • 通过这种类型的 JDBC 驱动程序访问数据库减少了 ODBC 的调用环节,提高了数据库访问的效率
  • 在这种方式下需要在客户的机器上安装本地 JDBC 驱动程序和特定厂商的本地 API

JDBC网络纯Java驱动程序

  • 这种驱动利用中间件的应用服务器来访问数据库。应用服务器作为一个到多个数据库的网关,客户端通过它可以连接到不同的数据库服务器。
  • 应用服务器通常有自己的网络协议,Java 用户程序通过 JDBC 驱动程序将 JDBC 调用发送给应用服务器,应用服务器使用本地程序驱动访问数据库,从而完成请求

本地协议的纯 Java 驱动程序

  • 多数数据库厂商已经支持允许客户程序通过网络直接与数据库通信的网络协议

  • 这种类型的驱动程序完全使用 Java 编写,通过与数据库建立的 Socket 连接,采用具体与厂商的网络协议把 JDBC 调用转换为直接连接的网络调用

最新文章

  1. Python初学者应了解的技巧
  2. oracle触发器与数据导入导出的简单使用
  3. 我读汤姆大叔的深入理解js(二)
  4. Altium Designer PCB双面板制作打印操作步骤
  5. Excel实用操作
  6. URAL 2046 A - The First Day at School 模拟题
  7. Scala官方作弊条
  8. Extjs4 MVC Controlller中refs使用
  9. C#设计模式总结(转)
  10. PHP buffer的机制
  11. Java集合详解2:LinkedList和Queue
  12. [转帖]无网络离线安装 vs2017
  13. 微信小程序设置域名、不校验域名
  14. ES5-ES6-ES7_字符串扩展—模板字符串
  15. 嵌入式-迅为iTOP-4418开发板Flash空间问题
  16. this指向问题,只提供案例,不做任何分析
  17. python3练习-发送IP地址到邮箱(使用日志)
  18. 详谈再论JAVA获取本机IP地址
  19. 将文件转换为base64字符串,然后还原
  20. openssl命令实例

热门文章

  1. 前端学习(八):CSS
  2. List<Activity> lists的关闭finish()
  3. 扫描PDF417崩溃的原因找到:手机摄像头分辨率低
  4. PHP入门之类型与运算符(一)
  5. PHP入门之流程控制
  6. PHPSTORM Live-Templates变量速查表
  7. IO—》字节流&字符流
  8. 解惑,什么是data-attribute ?
  9. Git文件合并
  10. 如何系统地学习Excel?