`
lixw
  • 浏览: 200850 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

JDBC 驱动程序揭密

阅读更多

 

转自:http://www-128.ibm.com/developerworks/cn/db2/library/techarticles/0307zikopoulos/0307zikopoulos.html

 

对 Java 产生混淆的常见根源是:JDBC 有不同的版本,JDBC 驱动程序有不同的类型,它们可以被不同版本的 Java 使用。而且,新的 Java 规范总是在开发之中,因为通过 Java 社区过程(Java Community Process,http://www.jcp.org ),相关的功能在不断地扩展中。

JDBC 版本

DB2 通用数据库 V8.1 支持 JDBC V2.1 规范和部分 JDBC 3.0 规范。使用通用 JDBC 驱动程序,全面支持 JDBC 3.0 需求的计划正在进行之中。

JDBC 驱动程序被认证为 J2EE 解决方案的一个组件。驱动程序认证的结果总是发布在 Sun 兼容性网站 上。

JDBC 驱动程序体系结构

JDBC 驱动程序体系结构分为四种类型。

  • Type 1
  • Type 2
  • Type 3
  • Type 4

JDBC Type 1 驱动程序

JDBC Type 1 驱动程序基于 JDBC-ODBC 桥。因此 ODBC 驱动程序可以与此类 JDBC 驱动程序(由 Sun 提供)结合起来使用。IBM 不支持 Type 1 驱动程序,因此它不是推荐的环境。图 1 显示了 JDBC Type 1 驱动程序的示例:

图 1. JDBC Type 1 驱动程序

JDBC Type 1 驱动程序

JDBC Type 2 驱动程序

JDBC Type 2 驱动程序依靠特定于操作系统的库(共享库)来与 RDBMS 通信。应用程序将装入这种 JDBC 驱动程序,而驱动程序将使用共享库来与 DB2 服务器通信。DB2 UDB for Linux, UNIX® 和 Windows® V8.1 提供了两种不同的 Type 2 驱动程序:

  • 旧的/CLI JDBC 驱动程序 在文件 db2java.zip 中提供。其实现包名称为 COM.ibm.db2.jdbc.app.DB2Driver 。该驱动程序目前已被用于进行 J2EE 认证。其别名“app 驱动程序”源自于一种观念及其包名称,这种观念就是:此驱动程序将通过远程数据库的本地 DB2 UDB 客户机执行本地连接。
  • 通用 JDBC 驱动程序 在文件 db2jcc.jar 中提供。其实现包名称为 com.ibm.db2.jcc.DB2Driver 。 此驱动程序是 DB2 UDB for Linux, UNIX 和 Windows V8.1 中的新功能。在最初的实现(V8.1)中,此驱动程序用于使用 Type 4 驱动程序体系结构与 DB2 服务器进行直接的 Java 连接。在 DB2 V8.1.2 中,您可以在 Type 2 体系结构中使用此驱动程序。在 Type 2 体系结构中使用此驱动程序的一个主要原因是为了本地应用程序性能和分布式事务支持。通用 JDBC Type 2 驱动程序分别使用 com.ibm.db2.jcc.DB2XADataSource com.ibm.db2.jcc.DB2ConnectionPoolDataSource 来支持分布式事务和连接池。

 

可以使用 JDBC Type 2 驱动程序来支持 JDBC 应用程序。WebSphere Application Server 同时支持这两种 Type 2 驱动程序。注:在将来的版本中不会对旧的/CLI Type 2 驱动程序进行增强。

图 2 显示了使用 JDBC Type 2 驱动程序的应用程序的典型拓扑结构:

图 2. 使用 JDBC Type 2 驱动程序的应用程序

JDBC Type 2 驱动程序

JDBC Type 3 驱动程序

JDBC Type 3 驱动程序是一种纯 Java 实现,它必须与 DB2 JDBC Applet 服务器(DB2 JDBC Applet Server)通信才能访问 DB2 数据。此类驱动程序旨在使 Java applet 能访问 DB2 数据源。在图 3 所显示的方案中,应用程序与安装有 DB2 客户机另一台机器进行通信。

图 3. 使用 Type 3 JDBC 驱动程序的典型应用程序方案

JDBC Type 3 驱动程序

JDBC Type 3 驱动程序常被称作“网络(net)驱动程序”,它是根据其包名 COM.ibm.db2.jdbc.net 命名的。DB2 V8.1 支持网络驱动程序,可以将其用于 JDBC 应用程序。

Type 3 驱动程序要求 db2java.zip 驱动程序总是处于与 DB2 Applet 服务器相同的维护级别。如果驱动程序在 applet 内使用,这就不是一个问题,因为浏览器会在应用程序执行期间下载相应的 db2java.zip 文件。许多客户使用 Type 3 驱动程序而不是 Type 2 驱动程序,以避免必需的 DB2 客户机安装和必需的 DB2 CATALOG DATABASE 命令,后者用于创建使用旧的/CLI 驱动程序进行 Type 2 连接所必需的数据库目录信息。目前,WebSphere Application Server 和其它 J2EE 服务器不支持 IBM Type 3 驱动程序,因为该驱动程序不支持分布式事务(JTA)。将来的版本不会对 Type 3 驱动程序进行增强。

我们鼓励使用通用 JDBC Type 4 驱动程序来替代 Type 3 驱动程序。

JDBC Type 4 驱动程序

Type 4 驱动程序是仅用于 Java 的 JDBC 驱动程序,它直接连接到数据库服务器。DB2 UDB for Linux, UNIX 和 Windows V8.1 引入了称为“通用 JDBC 驱动程序(Universal JDBC driver)”的 Type 4 驱动程序。通用 JDBC 驱动程序在文件 db2jcc.jar 中提供。其实现包名为 com.ibm.db2.jcc.DB2Driver

请注意,通用 Type 2 和通用 Type 4 驱动程序具有相同的实现类名称。有两种方法可以区别 DB2 在内部将实例化哪个驱动程序:

  • 使用连接特性来确定连接是否使用共享库(Type 2),或者驱动程序是否会启动来自 Java 应用程序的直接连接(Type 4)。
  • 使用不同的连接 URL 模式来指示您想要 Type 2 和 Type 4 行为中的哪一种。

    Type 4 URL 模式的示例:字符串“jdbc:db2://server1:50000/sample ”要求 JDBC 驱动程序将 Java 应用程序直接连接到 DB2 服务器上名为“sample”的数据库,该数据库位于配置在 DB2 服务器(主机名为 server1)上的 DB2 实例中,而 DB2 服务器则在端口 50000 上进行侦听。

    Type 2 URL 模式的示例:字符串“jdbc:db2:sample ”。有关 DB2 服务器(“server1”)和端口(“50000”)的信息可以在 DB2 客户机编目目录中找到。

 

通 用 JDBC 驱动程序是一种与驱动程序类型连通性或目标平台无关的抽象 JDBC 处理器。通用 JDBC 驱动器是一种与体系结构无关的 JDBC 驱动程序,用于进行分布式和本地 DB2 UDB 访问。因为通用 JDBC 驱动程序独立于任何特定 JDBC 驱动程序类型连通性或目标平台,所以它在一个 DB2 UDB 驱动程序实例中同时支持所有 Java 连通性(Type 4 驱动程序)和基于 JNI 的连通性(Type 2 驱动程序)。该驱动程序可以用于独立 Java 应用程序或多层应用程序。

重要: 就 DB2 UDB V8.1.2 而言,通用 JDBC 驱动程序要求 CLASSPATH 中有许可证 JAR 文件和 db2jcc.jar 文件。以下是所需的许可证 JAR 文件:

  • 对于 Cloudscape™ Network Server V5.1:db2jcc_license_c.jar
  • 对于 DB2 UDB V8 for Linux, UNIX 和 Windows 服务器:db2jcc_license_su.jar
  • 对于 DB2 UDB for iSeries® and z/OS 服务器(与 DB2 Connect 和 DB2 Enterprise Server Edition 一起提供):db2jcc_license_cisuz.jar

 

通用驱动程序可以通过使用预先安装在目标服务器上的必备存储过程,来查询数据库元数据目录及检索服务器错误消息文本:

  • 对于 Linux、UNIX 和 Windows 上的 UDB V8,这些存储过程是预先安装的。
  • 对于 DB2 UDB for OS/390® V6,必须安装 PTF UQ72081 和 UQ72082。
  • 对于 DB2 UDB for OS/390 and z/OS V7,必须安装 PTF UQ72083。即将推出的 z/OS 上的 DB2 UDB V8 将会预先安装必需的存储过程。
  • DB2 UDB for iSeries V5R1 需要 PTF SI06308、SI06300、SI06301、SI06302、SI06305、SI06307 和 SI05872。
  • DB2 UDB for iSeries V5R2 需要 PTF SI06541、SI06796、SI07557、SI07564、SI07565、SI07566 和 SI07567。DB2 UDB for iSeries V5R3 将会预先安装必需的存储过程。

 

图 4 中显示了 Type 4 JDBC 驱动程序实现。注:从 Linux、UNIX 和 Windows 上的 Java 应用程序或 applet 连接到 DB2 for z/OS and OS/390 所用的通用 JDBC/SQLJ 驱动程序(Type 4 和 Type 2)需要适当的许可证文件(db2jcc_license_cisuz.jar )。该许可证文件是随 DB2 Connect 产品一起提供的。

图 4. Type 4 JDBC 驱动程序实现
JDBC Type 4 驱动程序

 

附:

最近因为项目需要在WAS6.1上配置DB2V8数据源,Windows环境上的WAS配置成Type2是OK的,在UNIX环境上的数据源配置总是报错,后来修改成Type4就OK了,看完本文顿悟!

分享到:
评论

相关推荐

    注册Jdbc驱动程序的三种方式

    在Java编程中,连接数据库是常见且至关重要的任务,而注册JDBC驱动程序则是这个过程的第一步。JDBC(Java Database Connectivity)是Java语言访问数据库的标准API,它提供了与多种数据库进行交互的能力。本篇文章将...

    mysql jdbc 驱动 适用于5.7及以上版本数据库

    mysql jdbc 驱动 适用于5.7及以上版本数据库 mysql jdbc 驱动 适用于5.7及以上版本数据库 mysql jdbc 驱动 适用于5.7及以上版本数据库 mysql jdbc 驱动 适用于5.7及以上版本数据库 mysql jdbc 驱动 适用于5.7及以上...

    MySQL的JDBC 驱动程序

    MySQL的JDBC驱动程序是Java开发者连接到MySQL数据库的关键组件,它允许Java应用程序通过Java Database Connectivity (JDBC) API与MySQL服务器进行交互。在Java环境中,JDBC驱动程序扮演着桥梁的角色,使得开发者能够...

    sql sever 2000 jdbc 驱动程序

    SQL Server 2000 JDBC 驱动程序是微软为Java开发者提供的一个数据库连接工具,它允许Java应用程序通过Java Database Connectivity (JDBC) API与SQL Server 2000数据库进行交互。JDBC驱动程序是Java编程语言中的一个...

    Eclipse JDBC 驱动程序设置.txt

    标题与描述均提到了“Eclipse JDBC 驱动程序设置”,这暗示了文档主要讨论在Eclipse开发环境中配置JDBC驱动程序的过程,以便能够连接到数据库如Oracle和SQL Server。接下来,我们将深入探讨如何在Eclipse中设置JDBC...

    Oracle Database 11g 第 2 版 (11.2.0.4) JDBC 驱动程序— 包含 JDBC 示例程序。

    在这个压缩包中,我们得到了Oracle 11g的JDBC驱动程序,它包含了用于连接Oracle数据库的必要组件,以及一些示例程序,帮助开发者更好地理解和使用JDBC。 JDBC驱动程序是Oracle数据库与Java应用程序之间的桥梁,它...

    java 加载JDBC驱动程序

    JDBC驱动程序是实现这些接口的Java类库,它允许Java应用程序与各种类型的数据库进行交互。加载JDBC驱动程序是Java应用程序访问数据库的第一步,这个过程涉及到Java的反射机制和Class.forName()方法。下面我们将深入...

    oracle JDBC驱动程序

    Oracle JDBC驱动程序是Java应用程序与Oracle数据库之间通信的桥梁,使得开发者可以利用Java语言执行SQL语句和处理数据库数据。标题中的"10g与9i"指的是Oracle数据库的两个不同版本,即Oracle Database 10g和9i。这些...

    MySQLJDBC驱动程序

    MySQL数据库系统的JDBC驱动程序

    数据库JDBC驱动程序包

    数据库JDBC驱动程序包是一个非常重要的组件,尤其对于Java Web开发者而言,它是连接各种数据库的基础。JDBC(Java Database Connectivity)是Java编程语言中的一个标准API,它允许Java应用程序与各种类型的数据库...

    sqlserver2005 JDBC驱动程序JAR包

    **SQLServer2005 JDBC驱动程序JAR包详解** SQLServer2005 JDBC驱动程序是用于在Java应用程序中连接到Microsoft SQL Server 2005数据库的关键组件。JDBC(Java Database Connectivity)是一种Java API,允许Java...

    数据库系统的JDBC驱动程序.rar

    数据库系统的JDBC驱动程序是Java编程语言中与各种数据库进行交互的重要组成部分。JDBC(Java Database Connectivity)是一种标准API,由Sun Microsystems(现为Oracle公司)开发,它允许Java应用程序连接到不同类型...

    Oracle Database 19c(19.3)JDBC驱动程序 ojdbc10.jar

    Oracle Database 19c(19.3)JDBC驱动程序 通过JDK10认证; Oracle JDBC驱动程序

    EclipseJDBC 驱动程序设置

    ### Eclipse JDBC 驱动程序设置详解 #### 引言 在进行数据库开发与操作时,JDBC(Java Database Connectivity)驱动程序起着至关重要的作用,它为Java应用程序提供了访问数据库的标准接口。对于使用Eclipse作为...

    jdbc驱动程序.zip

    JDBC驱动程序是实现这些接口的软件组件,它作为桥梁连接Java应用程序和数据库服务器,提供了数据的读写、查询等功能。 标题中的"jdbc驱动程序.zip"暗示了这是一个包含JDBC驱动的压缩包文件,通常用于Java项目中与...

    SQL Server2000的JDBC驱动程序

    SQL Server 2000的JDBC驱动程序是微软为Java开发者提供的一种接口,使得Java应用程序能够连接到SQL Server数据库,执行SQL语句并处理结果。JDBC(Java Database Connectivity)是Java平台上的一个标准API,它允许...

    jdbc驱动程序

    标题中的“jdbc驱动程序”指的是Java Database Connectivity (JDBC) 驱动,这是一个Java API,用于在Java应用程序和各种数据库之间建立连接。它允许Java开发者执行SQL语句,进行数据查询、更新和删除等操作。 描述...

    jsp中jdbc驱动程序

    在Java服务器页面(JSP)中使用 JDBC(Java Database Connectivity)驱动程序是连接到数据库并执行SQL操作的关键步骤。JDBC提供了一种标准接口,使得Java应用程序能够与各种类型的数据库进行交互,无论数据库是...

    Oracle12C JDBC 驱动

    Oracle12C JDBC驱动是连接Java应用程序与Oracle数据库12c Release 2 (12.2.0.1) 的关键组件。JDBC(Java Database Connectivity)是Java平台中的一个标准API,它允许Java程序通过Java语言来访问和操作数据库。在...

    Oracle Database 11g 第 2 版 (11.2.0.4) JDBC 驱动程序

    Oracle Database 11g 第 2 版 (11.2.0.4) JDBC 驱动程序是用于连接Java应用程序与Oracle数据库的关键组件。JDBC(Java Database Connectivity)是一种标准API,允许Java程序员使用SQL语言来访问各种类型的数据库。在...

Global site tag (gtag.js) - Google Analytics