首页 > 编程语言 >[转帖]JDBC 驱动程序类型

[转帖]JDBC 驱动程序类型

时间:2024-06-19 13:21:50浏览次数:13  
标签:JDBC 驱动程序 数据库 ODBC 转帖 类型 Type

https://www.jianshu.com/p/fce9ac03a250

 

什么是 JDBC 驱动

说白了 JDBC 驱动就是一组实现了 JDBC API 接口的 Java 类的集合,该接口用于与数据库服务器进行交互。例如,使用 JDBC 驱动程序可以让你打开数据库连接,并通过发送 SQL 或数据库命令,然后通过 Java 接收结果。

JDK 中的 java.sql 包中定义了各种数据库操作相关的接口,这些接口的实现类交由第三方驱动程序中完成。第三方供应商在他们的数据库驱动程序中都实现了 java.sql.Driver 接口。

四种类型

以下四种类型的定义摘自维基百科
Type 1 : JDBC-ODBC bridge
Type 2 : Native-API driver
Type 3 : Network-Protocol driver (Middleware driver)
Type 4 : Database-Protocol driver (Pure Java driver) or thin driver

类型1:JDBC-ODBC 桥

在类型1中,一个 JDBC 桥接器是用来访问安装在每个客户机上的 ODBC 驱动程序。为了使用 ODBC,需要在目标数据库上配置系统数据源名称(DSN)。这种类型的驱动把所有 JDBC 的调用传递给ODBC,再让后者调用数据库的本地驱动代码。在 Java 刚出来的时候,这是一种很有用的方式,因为那时大多数的数据库只支持 ODBC 访问,但现在此类型的驱动程序仅适用于实验用途或在没有其他选择的情况。

  Type 1
  1. 优点:
    易于使用。
    只要有对应的 ODBC 驱动(大多数数据库厂商都会提供),所以几乎可以访问所有的数据库。

  2. 缺点:
    执行效率比较低,不适合大数据量访问的应用。
    需要客户端预装对应的 ODBC 驱动。

类型2:本地 API 驱动

在类型2中,JDBC API 调用转换成原生的 C/C++ API 的本地调用,这对于数据库来说具有唯一性。这些驱动程序通常由数据库供应商提供,并和 JDBC-ODBC 桥驱动程序的使用方式一样。该供应商的驱动程序同样必须安装在每台客户机上。

  Type 2
  1. 优点:
    速度快于Type 1(但比不上Type 3、Type 4)。

  2. 缺点:
    需要客户端预装对应的数据库厂商代码库。
    预装的代码库不是通用的,每家厂商各自独立,所以也依赖于数据库厂商。

类型3:网络协议驱动

在类型3中,JDBC 先把对数据库的访问请求传递给中间件服务器。中间件服务器再把请求翻译为符合数据库规范的调用,再把这种调用传给数据库服务器。如果中间件服务器也是用 java 开发的,那么在在中间层也可以使用Type 1、Type 2 这两种 JDBC 驱动方式访问数据库。

  Type 3
  1. 优点:
    不需要在客户端加载数据库厂商提供的代码库。
    单个驱动程序可以对多个数据库进行访问,可扩展性较好。
    支持数据库连接、查询结果的缓存,负载均衡,日志,监控等。

  2. 缺点:
    在中间件层仍需对最终数据进行配置。
    由于多出一个中间件层,速度不如 Type 4。

类型4:数据库协议驱动

类型4是纯粹的基于 Java 的驱动程序,通过 Socket 连接与厂商的数据库进行通信。这是可用于数据库的最高性能的驱动程序,并且通常由厂商自身提供。

  Type 4

这种驱动器是非常灵活的,你不需要在客户端或服务端上安装特殊的软件。此外,这些驱动程序是可以动态下载的。

MySQL Connector/J 的驱动程序是一个 Type 4。因为它们的网络协议的专有属性,数据库供应商通常提供 Type 4的驱动程序。

  1. 优点:
    平台独立的。
    相比于前三种方式不需要中间的媒介。
    应用程序直接同数据库服务器通信。
    访问速度最快。
    这是最直接、最纯粹的 Java 实现。

  2. 缺点:
    几乎只有数据库厂商自己才能提供这种类型的JDBC驱动。
    需要针对不同的数据库使用不同的驱动程序。

如何选择

如果你正在访问一个数据库,如 Oracle,Sybase 或 IBM,首选的驱动程序是类型4。

如果你的 Java 应用程序同时访问多个数据库类型,首选的是类型3。

类型2是在你的数据库没有提供类型3或类型4驱动程序时使用的。

类型1被认为不适合在生产种使用,它存在的目的通常仅用于开发和测试。

标签:JDBC,驱动程序,数据库,ODBC,转帖,类型,Type
From: https://www.cnblogs.com/jinanxiaolaohu/p/18256048

相关文章

  • [转帖]深入理解JDBC的超时设置
     https://www.cnblogs.com/Chary/articles/14958848.html 这是最近读到的讲关于JDBC的超时问题最透彻的文章,原文是http://www.cubrid.org/blog/understanding-jdbc-internals-and-timeout-configuration ,网上现有的翻译感觉磕磕绊绊的,很多上下文信息丢失了,这里用我......
  • 【操作系统】实验九 设备驱动程序设计
    一、实验目的分析一个典型的块设备RAM-DISK的驱动程序,学习编写设备驱动程序的一般过程。将这个RAM-DISK的程序改造成为U盘的驱动程序,并通过它来使用你的U盘。二、实验内容仔细阅读上一节中radimo的源代码,将radimo驱动程序改写成为一个U盘驱动程序。在检查时,你需要当场独......
  • Javaweb实现简易记事簿 jdbc实现Java连接数据库
    //注册-[]获取register的数据,从表单传过来将(账户,密码,用户名)上面的数据写入数据库中,用jdbc(插入)加载数据库驱动,连接数据库,发送SQL加载数据库有可能失败保险起见抛一个异常返回判断,如果注册成功则提醒用户注册成功,并且跳转到登录页面进行登录。如果注册失败则提醒用户注册失败,......
  • Javaweb实现简易记事簿 jdbc实现Java连接数据库
    //相关代码packageUserAct;importjakarta.servlet.;importjakarta.servlet.annotation.WebServlet;importjakarta.servlet.http.;importjava.io.;importjava.sql.;//登出@WebServlet("/UserAct.DeleteEvent")publicclassDeleteEventimplementsServlet{......
  • [转帖]工作中常用的命令
    https://cxd2014.github.io/2016/10/12/linux-command/  svn命令命令解释svncoserverUrl到serverUrl服务器上下载代码svncommit-m“log”filename将文件filename上传到服务器,”log”为修改日志svnup-rversionNum回到指定版本号versionNumsvn......
  • [转帖]端口复用
    https://cxd2014.github.io/2018/09/12/port-reuse/  SO_REUSEPORT套接字选项从Linux3.9内核版本之后Linux网络协议栈开始支持SO_REUSEPORT套接字选项,这个新的选项允许一个主机上的多个套接字绑定到同一个端口上,它的目的是提高运行在多核CPU上的多线程网络服务应用的处......
  • JDBC入门
    JDBC简介JDBC概念JDBC就是使用Java语言操作关系型数据库的一套API全称:(JavaDataBaseConnectivity)Java数据库连接JDBC是一套标准接口,实现同一套Java代码,操作不同的关系型数据库JDBC本质官方(sun)公司定义的一套操作所有关系型数据库的规则,即接口各个数据库厂商去实现这套接口......
  • CLFS驱动程序(clfs.sys)是Windows操作系统中的一个组件,它提供了日志记录和恢复功能,以增
    clfs.sys是Windows操作系统中的一个系统文件,它是CLFS(CommonLogFileSystem)驱动程序的一部分。CLFS是Windows操作系统中用于管理日志文件的文件系统,它提供了日志记录和恢复功能。CLFS驱动程序(clfs.sys)具有以下功能和作用:日志记录:CLFS可以记录系统的操作、事件和错误等信息到......
  • 传统后端SQL数据层替代解决方案: 内置数据源+JdbcTemplate+H2数据库 详解
    内置数据源我们回顾一下druid数据源的配置方式通过type属性指定数据源的类型导入依赖starter就使用了spring的自动装配功能格式二是在引入druid的依赖的基础上进行的一种配置方式Tomcat内部也可以进行数据源的配置轻量级中最快的数据源对象我们切换德鲁伊连接池......
  • Java与数据库连接技术JDBC关键核心之PreparedStatement以及SQL注入演示解决和原理
    PreparedStatementSQL注入执行预编译的SQL对象这样也能登录成功模拟SQL注入是这个原因现在基本上不存在SQL注入的问题解决SQL注入就是传一些语句导致原来的SQL语句改变了修改代码通过设置参数的方式就能防止SQL注入实际上我们进行了一个转化将字符和关......