[转帖]JDBC 驱动程序类型

news/2024/9/29 6:20:21
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被认为不适合在生产种使用,它存在的目的通常仅用于开发和测试。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hjln.cn/news/47065.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

[转帖]深入理解JDBC的超时设置

https://www.cnblogs.com/Chary/articles/14958848.html 这是最近读到的讲关于 JDBC 的超时问题最透彻的文章,原文是http://www.cubrid.org/blog/understanding-jdbc-internals-and-timeout-configuration ,网上现有的翻译感觉磕磕绊绊的,很多上下文信息丢失了,这里用我的理…

项目管理软件大对比:2024年10款最佳项目管理工具

一、禅道项目管理软件 1.禅道 禅道(ZenTao)是一款开源的项目管理软件,专门为敏捷开发和团队协作而设计。它提供了全面的项目管理功能,包括需求管理、任务管理、缺陷跟踪、测试管理、文档管理等,旨在帮助团队高效地进行项目规划、执行和交付。禅道目前可以提供全生命周期的…

rsync拷贝文件显示进度

rsync -a --info=PROGRESS2 test /ceshi/

mumu模拟器 adb shell 登录后执行命令 Inappropriate ioctl for device

前言全局说明mumu模拟器 adb shell 登录后执行命令 Inappropriate ioctl for device一、说明二、问题 执行任何命令,都提示: Inappropriate ioctl for device三、解决方法方法一:执行过sudo 或 su 重新登录 方法二: 退出,执行 adb root 后再执行 adb shell 登录四、免责声明…

【日记】被客户一顿输出该怎么办(431 字)

正文上午有个客户在电话里对着我一顿输出,说他们没有发票财务账务没法处理怎么怎么的。话里话外满满一股 “全是你们的错” 的味道。当时我很想笑,大姐,你对我输出有啥用啊。票是上级行开的,我们又没有开票权限,对我输出又解决不了问题,你去找市里啊。情况早就说了,纸质…

Postman 的 Basic Auth 如何通过 Feign 实现

Postman 的 Basic Auth: 分析 根据以上图片分析: Postman 的 Authorization 实际为: header 中添加 Authorization: ************** => "Base" + " " + base64("Username"+":"+"Password") => "Basic "+…

Thanos解码:打造企业级云原生监控解决方案

本文深入探讨了Thanos技术在云原生监控领域的应用,详细介绍了Thanos的基本概念、核心组件、安装配置步骤以及一个实战案例,帮助读者理解如何利用Thanos解决大规模监控数据的存储、查询和高可用性问题。关注作者,分享互联网架构、云服务技术的全维度知识。作者拥有10+年互联网…

运维之shell脚本初识

脚本工具可以帮助我们完成一些需要重复劳动的工作; 基础语法: "#"为注释符号 1:#指定脚本运行环境为 /bin/bash#! /bin/bash 2:输入参数,xxx为变量名,多个变量名用空格隔开read xxx 输出参数echo xxx 3: 变量和运算符的定义:这是每个编程语言必不缺少的部…