当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 通过JDBC连接DB2数据库技巧

MSSQL
SQL Server SA权限总结经典技术
ASP数据库编程SQL常用技巧
SQL SERVER数据库开发之存储过程应用
SQL Server 2000的安全配置
MSSQL经典语句
SQL 经典语句
有用的SQL语句(删除重复记录,收缩日志)
Access 数据类型与 MS SQL 数据类型的相应
SQL语句示例
SQL数据类型详解
将Sql Server对象的当前拥有者更改成目标拥有者
MSSQL内外连接(INNER JOIN)语句详解
SQL 外链接操作小结 inner join left join right join
SQL Server中网络备份一例
SQL语句导入导出大全
SQL 新增/修改 表字段列的类型等
系统存储过程,sp_executesql
sql2005开启xp_cmdshell
实例学习SQL的Select命令
删除数据库中重复数据的几个方法

MSSQL 中的 通过JDBC连接DB2数据库技巧


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 54 ::
收藏到网摘: n/a

关于DB2数据库的JDBC连接文章有很多,比较出名的有诸如“JDBC数据库连接大全”和“JSP的DB2连接数据库”,虽然都是很详细的资料,也都说解决了前人没有解决的问题,但还是有许多纰漏。我就这两天的经验给大家写一篇关于JDBC连接数据库的文章,以解决一部分人的疑问。

第一、JDBC是JDK的一部分(至少在Java Tiger Development Kits中是这样),使用JDBC直接在程序文件中写import Java.sql.*;即可使用了。

第二、连接字符串的格式。本地连接的连接字符串格式为jdbc:product_name: database_name,远程连接的格式为jdbc:product_name://host_name/port_ number:database_name。即如果我的数据库名字为rdb,则本地连接字符串为jdbc:db2:rdb(当然rdb一定是处于DB2的默认实例之中的),而远程连接字符串为jdbc:db2://192.168.1.10/50000:rdb(这里192.168.1.10为数据库所在服务器IP地址,而50000为DB2连接服务的端口号)。

第三、安装DB2数据库提供的为JDBC准备的类库(在.NET中叫Provider,在Java中怎么叫还没研究过)。查找IBM DB2 UDB的安装目录或者Java Tiger的JDK目录你会找到db2Java.zip,把它先做一个副本以后就它最有用了。现在我们开始讨论数据库连接的程序代码。

应用程序连接DB2数据库:

先将db2Java.zip解压缩,把COM目录转移到代码的当前目录,然后我们开始注册这个Provider的实例,代码为:

Class.forName(“COM.ibm.db2.jdbc.app.DB2Driver”).newInstance();

Class.forName(“COM.ibm.db2.jdbc.net.DB2Driver”).newInstance():

这两句任选其一,作用稍有不同,前者是具有DB2客户端的Provider实例,后者是无DB2客户端的Provider实例。

此后再写Connection con=DriverManager.getConnection();即可得到数据库连接的实例。

JSP中连接DB2数据库:

这里以Tomcat作为Servlet容器,如果想在Tomcat中使用DB2 Provider必须把db2java.zip更名成db2Java.jar然后复制到tomcat主目录下common\lib目录下,重新启动Tomcat这样就完成了Provider的注册。然后注册Provider实例的代码与上面等同。还有文章写到另一种注册Provider实例的方法:

DriverManager.registerDriver(new COM.ibm.db2.jdbc.app.DB2Driver());

DriverManager.registerDriver(new COM.ibm.db2.jdbc.net.DB2Driver());

数据库连接实例化方法同上。

深入探讨:

我本人不是很了解Tomcat的运行机制以及原理,不过通过测试发现直接从JSP页面连接DB2数据库会非常的慢。经过实践发现,最好的方法就是在Servlet中使用数据库连接代码,然后把数据库连接返回给JSP页面,十分方便,也便于集中处理代码问题。而且DB2的数据库连接中总会出现DB2服务器自己突然Down掉或者出现连接越发缓慢,这是DB2的实例及数据库参数配置不妥而引起的,我将会再另外的文章中详述,希望能帮助大家。