如何才能对DB2驱动类型有更好的理解

数据库
我们今天主要向大家描述的是DB2驱动类型的全面接触,你如果是DB2驱动类型的疯狂一族的话,以下的文章,你一定不要错过。

以下的文章主要是介绍DB2驱动类型全面接触,我们大家都知道IBM公司的数据库产品线中不同版本所提供的相关数据访问API,其可以说以是很多了,其中包括早期的基于CLI的驱动,最近的纯Java的驱动,以及CLI和 Java的组合。

对于特定的DB2版本的驱动有特定的驱动也有通用的驱动,这是很明显的.但是诸多版本的数据库系统和诸多版本的访问驱动,放在客户面前,它们之间的关系显得有些纷繁.

所以在使用IBM的数据库产品时,头脑中一定要注意版本对应和选择适当的通用驱动.还好,IBM已经开始走向统一了,也开始注意易用性了,这些努力从DB2 UDB V7就开始了.从那时开始,按照Java领域JDBC驱动的类型划分,IBM有了三类驱动了.

DB2的JDBC TYPE 2 驱动使 Java 应用程序通过JDBC调用DB2.对 DB2 JDBC type 2 driver 的调用被转换成 Java 本地方法.Java 使用这种驱动程序的应用程序必须运行在一个 DB2 客户机上,JDBC 请求通过这个客户机转到 DB2 服务器.

在使用 DB2 JDBC 应用程序驱动程序访问 DB2 UDB for iSeries 数据源或者 DB2 for OS/390 或 z/OS 环境中的数据源之前,必须安装 DB2 Connect Version 8.DB2 JDBC type 2 driver 支持 JDBC 1.2 规范中描述的大部分 JDBC 和 SQLJ 函数,并且支持 JDBC 2.0 规范中描述的一些函数.

DB2的JDBC TYPE 3 驱动,也被称为applet 或net driver,它由一个JDBC 客户机和一个JDBC 服务器(该进程的名字是db2jd)组成.既可以在Applet中使用也可以在应用程序中使用.

DB2的JDBC TYPE 4 驱动被称为通用驱动,是纯Java实现的,该驱动也支持SQLJ.

目前IBM一直都没有提供 TYPE 1的JDBC驱动程序.

这些类型驱动程序所在的包是:db2jcc.jar 和 sqlj.zip 文件,sqllib\bin\db2jcct2.dll(该文件是 TYPE2所必需的).

使用

在使用 JDBC 连接 DB2 UDB V7.2 和 DB2 UDB V8.1 时,如果碰到一些令人费解的问题,可以检查一下开发环境使用的JDK,在IBM提供的已知JDK中切换(目前有1.3和1.4版本),往往就能解决你的问题。

DB2 UDB V8.2个人版本中,下面的测试代码测试了三种连接方式,并给出了结果:

  1. import java.sql.*;  
  2. public class Employee {  
  3. /* 
  4. * @param args  
  5. */  
  6. public static void main(String[] args) {  
  7. // TODO Auto-generated method stub  
  8. Employee ee = new Employee();  
  9. try {  

ee.testJcc();//成功

ee.testNet();//成功

ee.testApp();//失败,原因是:类型2需要安装DB2访问客户端,测试没有安装.如果要通过类型2访问远程数据库,可以把远程数据库编目到本地后即可.

  1. } catch (Exception e) {  
  2. e.printStackTrace();  
  3. }  
  4. }  

内容导航

测试驱动体系结构为类型4驱动:com.ibm.db2.jcc.DB2Driver, 该驱动位于包db2jcc.jar中.

 

  1. @throws InstantiationException  
  2. @throws IllegalAccessException  
  3. @throws ClassNotFoundException  
  4. @throws SQLException  
  5. public void testJcc() throws InstantiationException,  
  6. IllegalAccessException, ClassNotFoundException, SQLException {  
  7. Class.forName("com.ibm.db2.jcc.DB2Driver").newInstance();  
  8. String url = "jdbc:db2://192.168.0.17:50000/SAMPLE";  
  9. Connection con = DriverManager.getConnection(url, "db2admin", "cherub");  
  10. con.setAutoCommit(false);  
  11. Statement stmt = con.createStatement();  
  12. ResultSet rs = stmt.executeQuery("select from Employee");  
  13. while (rs.next()) {  
  14. System.out.println(rs.getString(1) + "," + rs.getString(2));  
  15. }  
  16. }  

测试驱动体系结构为类型3驱动:COM.ibm.db2.jdbc.net.DB2Driver, 该驱动位于包 db2java.zip中.

  1. @throws InstantiationException  
  2. @throws IllegalAccessException  
  3. @throws ClassNotFoundException  
  4. @throws SQLException  
  5. public void testNet() throws InstantiationException,  
  6. IllegalAccessException, ClassNotFoundException, SQLException {  
  7. Class.forName("COM.ibm.db2.jdbc.net.DB2Driver").newInstance();  

// 目标DB2系统侦听该服务于默认端口6789,否则还需要在 URL Pattern 中指定目标端口号

  1. String url = "jdbc:db2:192.168.0.17:SAMPLE";  
  2. Connection con = DriverManager.getConnection(url, "db2admin", "cherub");  
  3. con.setAutoCommit(false);  
  4. Statement stmt = con.createStatement();  
  5. ResultSet rs = stmt.executeQuery("select from Employee");  
  6. while (rs.next()) {  
  7. System.out.println(rs.getString(1) + "," + rs.getString(2));  
  8. }  
  9. }  

测试驱动体系结构为类型2驱动:COM.ibm.db2.jdbc.app.DB2Driver, 该驱动也位于包 db2java.zip中.

  1. @throws InstantiationException  
  2.  
  3. @throws IllegalAccessException  
  4.  
  5. @throws ClassNotFoundException  
  6.  
  7. @throws SQLException  
  8.  
  9. public void testApp() throws InstantiationException,  
  10. IllegalAccessException, ClassNotFoundException, SQLException {  
  11. Class.forName("COM.ibm.db2.jdbc.app.DB2Driver").newInstance();  
  12. String url = "jdbc:db2:sample";  
  13. Connection con = DriverManager.getConnection(url, "db2admin", "cherub");  
  14. con.setAutoCommit(false);  
  15. Statement stmt = con.createStatement();  
  16. ResultSet rs = stmt.executeQuery("select from Employee");  
  17. while (rs.next()) {  
  18. System.out.println(rs.getString(1) + "," + rs.getString(2));  
  19. }  
  20. }  
  21. }  

以上的相关内容就是对DB2驱动类型全面接触的介绍,望你能有所收获。

【编辑推荐】

  1. 3个建议实现DB2数据库设计,很简单!
  2. 降低DB2管理表空间的高水位标记实操
  3. IBM DB2数据库错误信息的大集合,不得不看!
  4. DB2v9.5控制中心建库报错如何挽救?
  5. DB2 数据类型如何才能轻松接触?
责任编辑:佚名 来源: 163.com
相关推荐

2010-08-06 18:38:59

DB2快照函数

2010-08-09 15:44:44

DB2 数据类型

2010-08-02 14:03:49

DB2驱动类型

2010-07-27 15:02:30

DB2驱动类型

2010-09-07 10:24:26

DB2数据库

2010-08-31 14:04:49

DB2驱动

2010-08-11 09:14:33

DB2数据类型

2010-08-05 15:40:07

DB2快照函数

2010-08-03 13:45:17

DB2快照函数

2010-08-11 09:50:38

DB2 catalog

2010-11-02 11:22:06

DB2索引类型

2010-07-29 18:01:38

DB2性能

2010-08-18 10:46:38

DB2 code pa

2010-08-17 17:39:23

DB2取得当前时间

2010-08-26 10:13:52

DB2java连接

2010-08-16 11:34:11

IBM DB2 V9.

2010-08-05 09:14:29

DB2隔离级别

2010-07-28 14:16:43

DB2驱动类型

2010-08-17 15:31:54

DB2 存储过程

2010-08-20 10:26:25

DB2数据类型
点赞
收藏

51CTO技术栈公众号