以下的文章主要介绍的是如何用Oracle
Java的存储过程来访问异构数据库的实际操作,我们都知道在通常的企业实际应用中,Oracle数据库的类型可能会有多种,这些异构数据库之间的互连往往成为某个应用的瓶颈。
解决的办法有多种,一是透过应用
程序作为桥梁,在异构数据库之间牵线搭桥;二是数据库厂商提供的解决
方案,比如SQLServer的LinkServer,Oracle的TransparentGateway技术;三是通过数据库的应用扩展接口,例如Oracle的PL/SQL允许透过Java扩展访问外部数据库。
本文着眼于第三点,以Oracle连接SQLServer为例,探讨如何利用Java编写PL/SQL访问SQLServer,这点对于那些需要在非WINDOWS平台下访问SQLServer的Oracle应用特别有意义。
本文中
系统配置如下。
一、硬件及操作系统
DellIntelXeonServer+Windows2000Server
二、数据库环境
Oracle8.1.7
三、安装
欲使Oracle支持Java,必须在Oracle上安装Jserver组件。在安装Oracle
软件的时候,如果选择典型安装,Jserver是默认安装的,如果选择自定义安装,记得选择Jserver组件。还有另一种方法可以手工安装Jserver.办法是:
进入Oracle安装目录下的\javavm\install目录,以sys用户的身份执行initjvm.
sql,这个脚本会为数据库配置一个Java运行环境,同时会把基本的java类库装载到数据库中去。建议在执行此脚本之前,先阅读\javavm\readme.txt文件,里面包括安装前对数据库某些配置的必要修改的说明,以及对脚本执行出错的处理描述。
脚本执行时间大约10分钟,如果失败可以重新执行。
在脚本执行完毕后,用DBAStudio工具可以看到多了Jserver这个东西。
四、权限赋予
要能在Oracle中执行Java存储过程,需要一个javauserpriv的角色,这个角色在安装Jserver后会自动创建,将此角色赋给各个Oracle的使用账号。
五、编写OracleJava存储过程
1、在本地机器上编写一个Java类。
publicclassTEST{publicstaticvoidmain(Stringargs[]){System.out.println("HELLOTHISiSAJAVAPROCEDURE");}}2、用l
oadjava指令将写好的java类文件上传到数据库中。
例如:C:\>loadjava–utest/oracle@mytest-o–v–rd:\TEST.java
当然,除了上载.java文件,也可以上载.class/.jar/.properties文件,上载后的文件在数据库中会以Object的形式存在.
文件若有改动,可以重新上载,会将以前的版本覆盖掉。
3、生成声明接口
上载的java类需要发布成一个可供调用的接口,这些接口可以是StoreProcesure/Trrigger/Function等。
SQL>createorreplaceproceduretest_javaaslanguagejavaname'TEST.main(java.lang.String[])';/4、测试
SQL>setserveroutputonsize5000SQL>calldbms_java.set_output(5000);调用完成。
SQL>executetest_java;HELLOTHISiSAJAVAPROCEDUREPL/SQL过程已成功完成。
SQL>calltest_java();HELLOTHISiSAJAVAPROCEDURE调用完成。
5、以上是一个简单的java类,其实如果要在Oracle中访问到非Oracle的数据库,只