JDBC 驱动程序类型

什么是 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被认为不适合在生产种使用,它存在的目的通常仅用于开发和测试。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,590评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,808评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,151评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,779评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,773评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,656评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,022评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,678评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,038评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,756评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,411评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,005评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,973评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,053评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,495评论 2 343

推荐阅读更多精彩内容